micropython中怎么将gb2312编码的字节流变成中文

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了micropython中怎么将gb2312编码的字节流变成中文相关的知识,希望对你有一定的参考价值。

# -*- code: utf-8 -*-
# 在 micropython 中运行, 注意在运行目录下有 hzk12/16

# '啊' 是汉字区第1个汉字,对应数据为 ?不对?
# 0x00, 0x00, 0x0E, 0xFC, 0xEA, 0x08, 0xAA, 0x08,
# 0xAA, 0xE8, 0xAA, 0xA8, 0xAC, 0xA8, 0xAA, 0xA8,
# 0xAA, 0xA8, 0xAA, 0xA8, 0xEA, 0xE8, 0xAA, 0xA8,
# 0x0C, 0x08, 0x08, 0x08, 0x08, 0x28, 0x08, 0x10
# hzk16 试验: '一','我'正确, '啊' 不对?
# hzk12 字库的位长度是16*12
# seek位置 '一': 111168, '五': 103152, '我':102196

'''
int(x [,base ])         将x转换为一个整数    
long(x [,base ])        将x转换为一个长整数    
float(x )               将x转换到一个浮点数    
complex(real [,imag ])  创建一个复数    
str(x )                 将对象 x 转换为字符串    
repr(x )                将对象 x 转换为表达式字符串    
eval(str )              用来计算在字符串中的有效Python表达式,并返回一个对象    
tuple(s )               将序列 s 转换为一个元组    
list(s )                将序列 s 转换为一个列表    
chr(x )                 将一个整数转换为一个字符    
unichr(x )              将一个整数转换为Unicode字符    
ord(x )                 将一个字符转换为它的整数值    
hex(x )                 将一个整数转换为一个十六进制字符串    
oct(x )                 将一个整数转换为一个八进制字符串
bytearray(x)            列表转为数组
'''
from machine import Pin, I2C
import framebuf
import ssd1306
i2c = I2C(sda=Pin(5), scl=Pin(4))
o = ssd1306.SSD1306_I2C(128,64,i2c)

def drawhz( hzs, xp, yp ):
for x in range( len(hzs)//2 ):
c = ((hzs[x*2] - 0xA1)* 94 + (hzs[x*2+1] - 0xA1)) * 24  #gb2312 转成 区位号
f = open( 'uc_hzk12', 'rb' )
f.seek( c )
hz = bytearray( f.read(24) )
f.close()

# 创建 hzk12:16x12 or hzk16:16x16 大小帧缓存区储存图片帧,水平扫描
fb1 = framebuf.FrameBuffer(hz, 16, 12, framebuf.MONO_HLSB)
o.blit( fb1, xp + x*12, yp )  # 将fb1帧缓存送至oled显示,起始位(38,16)
xp += 1

#在 repl 中, 粘贴的中文件变码了, 装载文件形式才正常
def drawhz2(hzs, xp, yp):
for x in range(len(hzs)):
f = open('uni2gb', 'rb')
f.seek( (ord(hzs[x])-0x4e00)*2 )
gb23 = bytearray(f.read(2))
f.close()
c = ((gb23[0] - 0xA1) * 94 + (gb23[1] - 0xA1)) * \\
24  # gb2312 转成 区位号
f = open('uc_hzk12', 'rb')
f.seek(c)
hz = bytearray(f.read(24))
f.close()

# 创建 hzk12:16x12 or hzk16:16x16 大小帧缓存区储存图片帧,水平扫描
fb1 = framebuf.FrameBuffer(hz, 16, 12, framebuf.MONO_HLSB)
o.blit(fb1, xp + x*12, yp)  # 将fb1帧缓存送至oled显示,起始位(38,16)
xp += 1

o.fill(0)
# uPY没法实现unicode 转 gb2312, 要借助cpython 转化成 gb2312
#现在可用 文件查表法 uni2gb  (unicode-0x4e00)转gb2312码
hzs = ( 206,210, 185,253, 193,249, 210,187, 189,218 ) #每两字节表示一个汉字
drawhz2( '\\u98de\\u96ea\\u8fde\\u5929', 0, 0 )
drawhz2( '\\u98de\\u96ea\\u8fde\\u5929\\u5c04\\u767d\\u9e7f', 0, 13 )  #飞雪连天
drawhz( hzs, 0, 26 )
drawhz( hzs, 16, 39)
drawhz( hzs, 16, 52 )
o.show()

参考技术A micropython中好像还没有unicode方面的支持,中文解码也还没有。
不过可以参考这样的想法,GB2312编码的汉字都是双字节,ASC码都是大于127的.这样如果连续两个字符都是大于127的,就可以当成一个汉字处理。

source insight4怎么处理gb编码

参考技术A 1、Document Options -> Screen Fonts -> 字体设置为新宋体(等宽)或者其他支持中文的字体,字符集选GB2312 2、Preferences -> Syntax Formatting -> Use only color formatting前面的钩挑上。

以上是关于micropython中怎么将gb2312编码的字节流变成中文的主要内容,如果未能解决你的问题,请参考以下文章

怎么将java代码的编码方式设置为gb2312

Java怎么将字符串转换为GB2312原编码

vs2017 cshtml 文件编码怎么设置为 gb2312

Java怎么将字符串转换为GB2312原编码

PHP中当前文件为GBK或GB2312编码,怎么用正则表达式取汉字

MicroPython ESP32ssd1306模块基于GB2312字库驱动0.96“I2C屏幕汉字显示示例