icd编码43.81什么时候使用

icd编码43.81什么时候使用,第1张

根据国家卫健委三级公立医院绩效考核标准的相关要求,我院今后上报的数据需要以国家卫健委下发的“国家临床版20疾病诊断编码(ICD-10)”和“国家临床版20手术 *** 作编码(ICD-9-CM3)”为准。新版的ICD-10编码共有“37253”条;新版ICD-9-CM3编码共有 “12855”条。

新下发的ICD字典与现正在使用的老字典相比,除了完全新增加的编码外,还有如下情况:

1在新老字典中,有的ICD编码相同,但是疾病名称不同,如图 1所示。

图1 ICD编码相同,疾病名称不同

2在新老字典中,疾病名称相同,但是ICD编码不同。如图2 所示:

所以在新老字典更新过程中,可能会影响到的应用程序包括:

1)门诊医生站;

2)住院医生站;

3)电子病历;

4)临床路径;

5)病案统计;

6)传染病上报;

7)其它与HIS做接口并调用ICD字典的第三方程序:如急诊信息系统,康复信息系统,PACS系统,LIS系统等。

为保证全院统计工作的连续性,我院拟于7月3日进行编码库的更新(出院病人以2019年6月30日,作为新老字典的切换截断点)。

1990年3月20日,原卫生部在《关于医院使用统一的病案首页的通知》中正式提出病案首页使用ICD-9的国际疾病统一编码

什么是垃圾:当一个值身上没有人绑定任何变量名(该值的引用计数=0)时,该值就是一个垃圾,会将该值内存空间释放掉。

引用计数增加

age=18 //18的引用计数等于1

x=age //18的引用计数等于2

引用计数减少

age=19 //18的引用计数等于1

del x //解除值与变量名的绑定关系;18的引用计数变为0

1、 为何数据要分不同的类型?

数据是用来表示状态的,不同的状态就应该用不同的类型的数据去表示

2、数据类型

数字(整形,长整形,浮点型,复数)

字符

字节串:在介绍字符编码时介绍字节bytes类型

列表

元组

字典

集合

3、按照以下几个点展开数据类型的学习

==========================基本使用============================

1、用途

2、定义方式

3、常用 *** 作+内置的方法

==========================该类型总结==========================

存一个值or存多个值

有序or无序

可变or不可变(1、可变:值变,id不变。可变==不可hash 2、不可变:值变,id就变。不可变==可hash)

1、整型int

作用:年纪,等级,身份z号,qq号等整型数字相关

定义:age=10 #本质age=int(10)

2、浮点型float

作用:薪资,身高,体重,体质参数等浮点数相关

salary=30003 #本质salary=float(30003)

类型转换

a=('123') //字符串类型

a=int('123') //字符串转成整型类型

a=float('123') //字符串转成浮点型

作用:记录多个值

定义方式:在[ ]内用逗号分隔开多个任意类型的值;原材料可以是字符串,列表,字典;可变类型

1、按索引存取值(正向存取+反向存取);可存也可以修改;对于赋值 *** 作必须是已存在的索引

l=['a','b','c','d','e']

print(l[0]) =a

print(l[-1]) =e

l[0]='A' //修改列表

print(l) =['A','b','c','d','e']

2、切片(顾头不顾尾,步长),步长与字符串一样;原列表不会修改

print(l[1:4]) =['b','c','d']

3、长度

print(len(l)) =5

4、成员运算in和not in

print('a' in l) =True

print('sss' not in l) =True

5、追加&插入

lappend(333) //append最后追加

print(l) =['a','b','c','d','e','333']

linsert(0,111) //第一个位置添加值

print(l) =['111','a','b','c','d','e']

6、删除remove ,有返回值;del也可删,但是没有返回值;pop 剪切一个值,返回剪切的值

lremove('a') //()内为值,不能为索引

print(l) =['b','c','d','e']

del l[0] //[ ] 内为索引

lpop(0) // () 内为索引,不指定索引默认时-1

res=lpop(0)

print(res) =a

7、循环

for item in l

print(item)

1、count 统计次数

print(lcount('a')) =1

2、extend 一次性往列表末尾追加多个值,一个参数:可以被 for 循环的列表

item=[1,2,3,4,5]

lextend(item)

print(l) =['a','b','c','d','e',1,2,3,4,5]

3、index 找索引,以找到的第一个值为准,不存在的值会报错,可以用成员运算判断查找的值是否存在,以避免报错;列表没有find

print(lindex('a')) =0

print(lindex('c',2,5)) =2 //指定查找范围,第二个开始,第五个结束

4、sort 排序,默认从小到大排序

l=[4,6,2,9,10,3,1]

lsort()

print(l) =[1, 2, 3, 4, 6, 9, 10]

lsort(reverse=True) //从大到小排序

print(l) =[10, 9, 6, 4, 3, 2, 1]

作用:就是一个不可变的列表(是可以当做字典的key的),主要是用来读

定义:在()内用逗号分隔开多个任意类型的元素

t=(1,2,3,('a','b'),['q','w','e'])

本质age=tuple(t=(1,2,3,('a','b'),['q','w','e']))

如果元组只有一个值,必须加一个逗号

t=('a',)

元组总结

1、存多个值

2、有序

3、不可变

1、按索引取值(正向取+反向取):只能取,不能添加、减少、修改

t=(1,2,3,('a','b'),['q','w','e'])

print(t[0]) =1

print(t[-1]) =['q','w','e']

2、切片(顾头不顾尾,步长),步长与字符串一致

print(t[1:4]) =(2, 3, ('a', 'b'))

3、长度

print(len(t)) =5

4、成员运算in和not in

print(1 in t) =True

5、循环

for item in t:

print(item)

t=(1,2,3,('a','b'),3,['q','w','e'])

作用:记录多个值,key对应值,key对value有描述性功能;取值速度快

定义:在{ } 内用逗号隔开多个元素,每个元素都是key:value的形式;key必须是不可变类型,value可以是任意类型

info={'name':'egon','age':18,'sex':'male'}

本质

info=dict(name='egon',age=18,sex='male')

info=dict([['name','egon'],('age',18)])

{}fromkeys(('name','age','sex'),None)

总结

1、存多个值

2、无序

3、可变

1、将值导入字典

2、按key存取值:可存可取

dic={'name': 'egon', 'age': '18', 'gender': 'male'}

print(dic['name']) =egon //当key不存在时会报错

print(dicget('name')) =egon

print(dicget('xxx')) =None //当key不存在时会返回一个None

dic['name']='Egon' //修改value

dic['hight']=18 //如果key不存在,就是一个加值的 *** 作

print(dic) ={'name': 'egon', 'age': '18', 'gender': 'male', 'hight': 18}

3、长度len,统计key:value的个数; 不能有重复的key,后面的key会覆盖前面的key

print(len(dic)) =3

4、成员运算in和not in,以字典的key为准

print('name' in dic) =True

print('dasda' not in dic) =True

5、删除

第一种:del dic['name']

第二种:res=dicpop('name') //根据key删除,有返回值,返回值为key对应的value值

第三种:res=dicpopitem() //随机删,返回值是(key:value),返回值格式是元组

6、键keys(),值values(),键值对items()

print(dickeys()) =dict_keys(['name', 'age', 'gender']) //取索引

print(dicvalues()) =dict_values(['egon', '18', 'male']) //取值

print(dicitems()) =dict_items([('name', 'egon'), ('age', '18'), ('gender', 'male')]) //取键值对

7、循环

for item in dic:

print(item) //输出的是key

for item in dicvalues():

print(item) //输出的是值

for item in dicitems():

print(ietm) //输出的是 (key:value) 的元组

1、update 新字典中已经存在的以新的为准,不存在的增加

dic={'name': 'egon', 'age': '18', 'gender': 'male'}

dicupdate({'age':19,'hight':180})

print(dic) ={'name': 'egon', 'age': 19, 'gender': 'male', 'hight': 180}

2、setdefault 加入一个键值对,如果key已存在,则保留字典里的原值,如果key不存在,则加入键值对;返回字典里key对应的value值

作用:关系运算,去重

定义方式:在{ }内用逗号分隔开多个元素,但是元素的特点是

1、每个元素必须是不可变类型(可hash,可作为字典的key)

2、没有重复的元素

3、无序

注意:集合的目的是将不同的值存放到一起,不同的集合间用来做关系运算,无需纠结于集合中单个值

类型转换

res=set('hello') //字符串转集合

rds=set([1,'a','b']) //列表转集合

print(res) ={'h', 'l', 'e', 'o'} //去重

print(rds) ={1, 'a', 'b'}

总结:

1、有多个值

2、无序

3、可变

pythons={'alex','egon','yuanhao','wupeiqi','gangdan','biubiu'}

linuxs={'wupeiqi','oldboy','gangdan'}

1、长度len

2、成员运算in和not in

3、合集

print(pythons | linuxs)

4、&交集

print(pythons & linuxs)

5、两个集合差集,以第一个集合为准

print(pythons - linuxs) //求只报名python的学生

print(linuxs - pythons) //求只报名linux的学生

6、对称差集;求没有报名两门课程的学生

第一种:res=(pythons - linuxs) | (linuxs - pythons)

第二种:res=pythons ^ linuxs

print(res)

7、== ,集合值相等即可,无需顺序一致

s1={1,2,3}

s2={3,2,1}

print(s1 == s2) =True

8、父集:>,>= ;子集:<,<=

s1={1,2,3}

s2={3,2,1,4,6}

print(s2 >= s1) =True

print(s1 <= s2) =True

介绍:计算机系统分为:计算机硬件, *** 作系统,应用程序三部分。

1、什么是文件

文件是 *** 作系统为应用程序或者用户提供一种 *** 作硬盘的虚拟单位。

window系统默认为GBK编码

2、为什么要用文件?

文件对应的硬盘空间,如果需要考虑永久保存数据那必须使用文件

3、如何用文件?

(1)打开文件

f=open(r'D:\untitled1\atxt',mode='r',encoding='utf-8')

第一个小r,表示原生的字符串,\没有转义的意思,防止\a、\n转义

第二个小r,以读的模式打开,rb以二进制格式读,rt会把文本文件二进制解码成unicode格式存到内存,针对文本文件用rt模式;w为写 *** 作;

赋值给一个变量,变量指定该文件对象,文件对象占的是应用程序的资源

(2)读/写文件

(3)关闭文件

fclose() //向 *** 作系统发送指令,让 *** 作系统关闭打开的文件,回收 *** 作系统资源

1、控制文件读写 *** 作模式

r 只读模式,以该模式打开文件,当文件不存在时报错;

w 只写模式,如果该文件存在则覆盖,如果该文件不存在,创建新文件写入;文件打开不关闭的情况下,连续写入自动追加;

a 追加,如果该文件存在则文件结尾追加内容,如果该文件不存在,创建新文件写入;

w+ 读写,如果该文件存在则覆盖,如果该文件不存在,创建新文件写入

2、控制文件读写内容的模式(不能单独使用,必须与r、w、a连用)

t (默认) 读写只能是文本文件,都是字符串类型,会自动解码文本文件;必须指定encoding参数

b 对于非文本文件,我们只能使用b模式,linux可忽略;"b"表示以字节的方式 *** 作;以b方式打开时,读取到的内容是byte字节类型,写入时也需要提供字节类型,不能指定编码

为了避免打开文件后忘记关闭,可以通过管理上下文,即:

with open('log','r') as f:

3、文件的修改

fseek(3,0) //3指移动的字节数,0是模式

1、三种模式,以字节为单位;只有0模式既可以在t模式下用也可以在b模式下用,而1、2两种模式只能在b模式下用

0 (默认模式):永远参照文件开头往后数

1:参照指针当前所在位置

2:参照文件末尾,倒着数

注意:t 模式下的read(n) 是以字符为单位;意思为从哪个字符开始读

coding

编码定义

编码是根据一定的协议或格式把模拟信息转换成比特流的过程。

在计算机硬件中,编码(coding)是在一个主题或单元上为数据存储,管理和分析的目的而转换信息为编码值(典型地如数字)的过程。在软件中,编码意味着逻辑地使用一个特定的语言如C或C++来执行一个程序。在密码学中,编码是指在编码或密码中写的行为。

将数据转换为代码或编码字符,并能译为原数据形式。是计算机书写指令的过程,程序设计中的一部分。在地图自动制图中,按一定规则用数字与字母表示地图内容的过程,通过编码,使计算机能识别地图的各地理要素。

n位二进制数可以组合成2n个不同的信息,给每个信息规定一个具体码组,这种过程也叫编码。

数字系统中常用的编码有两类,一类是二进制编码,另一类是二—十进制编码。

汉字的编码体系

1.ASCII与Binary

我们日常接触到的文件分ASCII和Binary两种。ASCII是“美国信息交换标准编码”的英文字头缩写,可称之为“美标”。美标规定了用从0到127的128个数字来代表信息的规范编码,其中包括33个控制码,一个空格码,和94个形象码。形象码中包括了英文大小写字母,阿拉伯数字,标点符号等。我们平时阅读的英文电脑文本,就是以形象码的方式传递和存储的。美标是国际上大部分大小电脑的通用编码。

然而电脑中的一个字符大都是用一个八位数的二进制数字表示。这样每一字符便可能有256个不同的数值。由于美标只规定了128个编码,剩下的另外128个数码没有规范,各家用法不一。另外美标中的33个控制码,各厂家用法也不尽一致。这样我们在不同电脑间交换文件的时候,就有必要区分两类不同的文件。第一类文件中每一个字都是美标形象码或空格码。这类文件称为“美标文本文件”(ASCII Text Files),或略为“文本文件”,通常可在不同电脑系统间直接交换。第二类文件,也就是含有控制码或非美标码的文件,通常不能在不同电脑系统间直接交换。这类文件有一个通称,叫“二进制文件”(Binary Files)。

2.国标、区位、“准国标”

“国标”是“中华人民共和国国家标准信息交换用汉字编码”的简称。国标表(基本表)把七千余汉字、以及标点符号、外文字母等,排成一个94行、94列的方阵。方阵中每一横行叫一个“区”,每个区有九十四个“位”。一个汉字在方阵中的坐标,称为该字的“区位码”。例如“中”字在方阵中处于第54区第48位,它的区位码就是5448。

其实94这个数字。它是美标中形象码的总数。国标表沿用这个数字,本意大概是要用两个美标形象符代表一个汉字。由于美标形象符的编码是从33到126,汉字区、位码如果各加上32,就会与美标形象码的范围重合。如上例“中”字区、位码加上32后,得86,80。这两个数字的十六进制放在一起得5650,称为该字的“国标码”,而与其相对应的两个美标符号,VP,也就是“中”字的“国标符”了。

这样就产生了一个如何区分国标符与美标符的问题。在一个中英文混用的文件里,“VP”到底代表“中”字呢,还是代表某个英文字头缩写?电子工业部第六研究所开发CCDOS的时候,使用了一个简便的解决方案:把国标码的两个数字各加上128,上升到非美标码的位置。(改变后的国标码,习惯上仍叫“国标”。)

这个方案固然解决了原来的问题,可是新的问题随之产生。中文文件成了“二进制文件”,既不能可靠地在不同电脑系统间交换,也不与市场上大部分以美标符号为设计对象的软件兼容。

为了区分以上两种“国标”,我们把原与美标形象码重合的国标码称为“纯国标” ,而把CCDOS加上128的国标码称为“准国标”。

3.GBK码:

GBK码是GB码的扩展字符编码,对多达2万多的简繁汉字进行了编码,简体版的Win95和Win98都是使用GBK作系统内码。

从实际运用来看,微软自win95简体中文版开始,系统就采用GBK代码,它包括了TrueType宋体、黑体两种GBK字库(北京中易电子公司提供),可以用于显示和打印,并提供了四种GBK汉字的输入法。此外,浏览器IE40简体、繁体中文版内部提供了一个GBK-BIG5代码双向转换功能。此外,微软公司为IE提供的语言包中,简体中文支持(Simplified Chinese Language Support Kit)的两种字库宋体、黑体,也是GBK汉字(珠海四通电脑排版系统开发公司提供)。其他一些中文字库生产厂商,也开始提供TrueType或PostScript GBK字库。

许多外挂式的中文平台,如南极星、四通利方(Richwin)等,提供GBK码的支持,包括字库、输入法和GBK与其他中文代码的转化器。

互联网方面,许多网站网页使用GBK代码。

但是多数搜索引擎都不能很好的支持GBK汉字搜索,大陆地区的搜索引擎有些能不完善的支持GBK汉字检索。

其实,GBK是又一个汉字编码标准,全称《汉字内码扩展规范》(Chinese Internatial Code Specification),1995年颁布。GB是国标,K是汉字“扩展”的汉语拼音第一个字母。

GBK向下与GB-2312编码兼容,向上支持ISO 106461国际标准,是前者向后者过渡的一个承启标准。

GBK规范收录了ISO 106461中的全部CJK汉字和符号,并有所补充。具体包括:GB 2312中的全部汉字、非汉字符号;GB 130001中的其他CJK汉字。以上合计20902个GB化汉字;《简化总表中》未收入GB 130001的52个汉字;《康熙字典》以及《辞海》中未被收入GB 130001的28个部首及重要构件;13个汉字结构符;BIG-5中未被GB 2312收入、但存在于GB 130001的139个图形符号;GB 12345增补的6个拼音符号;GB 12345增补的19个竖排图形符号(GB 12345较GB 2312增补竖排标点符号29个,其中10个未被GB 130001收入,故GBK亦不收);从GB 130001的CJK兼容区挑选出的21个汉字;GB 130001收入的31个IBM OS/2专用符号。GBK亦采用双字节表示,总体编码范围为0x8140~0xFEFE之间,首字节在0x81~0xFE之间,尾字节在0x40~0xFE之间,剔除0x××7F一条线,总计23940个码位,共收入21886个汉字和图形符号,其中汉字(包括部首和构件)21003个,图形符号883个。

4.BIG5码:

BIG5码是针对繁体汉字的汉字编码,目前在台湾、香港的电脑系统中得到普遍应用。BIG5码的编码范围参考下文。

5.HZ码:

HZ码是在Internet上广泛使用的一种汉字编码。“HZ”方案的特点,是以“纯国标”的中文与美标码混用。那么“HZ”是怎样区分国标符和美标符的呢?答案其实也很简单:当一串美标码中间插入一段国标码的时候,我们便在国标码的前面加上~,后面加上~。这些附加码分别叫“逃出码”和“逃入码”。 由于这些附加码本身也是美标形象码,整个文件就俨然是一个美标文本文件,可以安然地 在电脑网上传递,也和大部分英文文本处理软件兼容。

6.ISO-2022CJK码:

ISO-2022是国际标准组织(ISO)为各种语言字符制定的编码标准。采用二个字节编码,其中汉语编码称ISO-2022 CN,日语、韩语的编码分别称JP、KR。一般将三者合称CJK码。目前CJK码主要在Internet网络中使用。

7.UCS 和 ISO 10646:

1993年,国际标准ISO10646 定义了通用字符集 (Universal Character Set, UCS)。 UCS 是所有其他字符集标准的一个超集。它保证与其他字符集是双向兼容的。就是说, 如果你将任何文本字符串翻译到 UCS格式,然后再翻译回原编码, 你不会丢失任何信息。

UCS 包含了用于表达所有已知语言的字符。不仅包括拉丁语,希腊语,斯拉夫语,希伯来语,阿拉伯语,亚美尼亚语和乔治亚语的描述, 还包括中文,日文和韩文这样的象形文字,以及平假名,片假名,孟加拉语, 旁遮普语果鲁穆奇字符(Gurmukhi), 泰米尔语, 印埃纳德语(Kannada),Malayalam,泰国语, 老挝语, 汉语拼音(Bopomofo), Hangul,Devangari,Gujarati, Oriya,Telugu 以及其它语种。对于还没有加入的语言, 由于正在研究怎样在计算机中最好地编码它们, 因而最终它们都将被加入。这些语言包括Tibetian,高棉语,Runic(古代北欧文字),埃塞俄比亚语, 其他象形文字,以及各种各样的印-欧语系的语言,还包括挑选出来的艺术语言比如 Tengwar,Cirth 和 克林贡语(Klingon)。UCS 还包括大量的图形的,印刷用的,数学用的和科学用的符号,包括所有由 TeX,Postscript, MS-DOS,MS-Windows, Macintosh, OCR 字体, 以及许多其他字处理和出版系统提供的字符。

ISO 10646 定义了一个 31 位的字符集。 然而, 在这巨大的编码空间中, 迄今为止只分配了前 65534 个码位 (0x0000 到 0xFFFD)。这个UCS的16位子集称为基本多语言面 (Basic Multilingual Plane, BMP)。 将被编码在16位BMP以外的字符都属于非常特殊的字符(比如象形文字), 且只有专家在历史和科学领域里才会用到它们。按当前的计划, 将来也许再也不会有字符被分配到从0x000000到0x10FFFF这个覆盖了超过100万个潜在的未来字符的 21 位的编码空间以外去了。ISO 10646-1标准第一次发表于1993年, 定义了字符集与 BMP 中内容的架构。定义 BMP以外的字符编码的第二部分 ISO 10646-2 正在准备中, 但也许要过好几年才能完成。新的字符仍源源不断地加入到 BMP 中, 但已经存在的字符是稳定的且不会再改变了。

UCS 不仅给每个字符分配一个代码, 而且赋予了一个正式的名字。表示一个 UCS 或 Unicode 值的十六进制数, 通常在前面加上 “U+”, 就象U+0041 代表字符“拉丁大写字母A”。UCS字符U+0000到U+007F 与 US-ASCII(ISO 646) 是一致的, U+0000 到 U+00FF 与 ISO 8859-1(Latin-1) 也是一致的。从 U+E000 到 U+F8FF,已经BMP 以外的大范围的编码是为私用保留的。

1993年,ISO10646中定义的USC-4 (Universal Character Set) ,使用了4 个字节的宽度以容纳足够多的相当可观的空间,但是这个过于肥胖的字符标准在当时乃至现在都有其不现实的一面,就是会过分侵占存储空间并影响信息传输的效率。 与此同时,Unicode 组织于约 10 年前以 Universal, Unique和Uniform 为主旨也开始开发一个16位字符标准, 为避免两种16位编码的竞争,1992年两家组织开始协商,以期折衷寻找共同点,这就是今天的 UCS-2 (BMP,Basic Multilingual Plane,16bit) 和Unicode,但它们仍然是不同的方案。

8.Unicode码:

关于Unicode我们需要追溯一下它产生的源源。

当计算机普及到东亚时,遇到了使用表意字符而非字母语言的中、日、韩等国家。在这些国家使用的语言中常用字符多达几千个,而原来字符采用的是单字节编码,一张代码页中最多容纳的字符只有28=256个,对于使用表意字符的语言是在无能为力。既然一个字节不够,自然人们就采用两个字节,所有出现了使用双字节编码的字符集(DBCS)。不过双字节字符集中虽然表意字符使用了两个字节编码,但其中的ASCII码和日文片假名等仍用单字节表示,如此一来给程序员带来了不小的麻烦,因为每当设计到DBCS字符串的处理时,总是要判断当中的一个字节到底表示的是一个字符还是半个字符,如果是半个字符,那是前一半还是后一半?由此可见DBCS并不是一种非常好的解决方案。

人们在不断寻找这更好的字符编码方案,最后的结果就是Unicode诞生了。Unicode其实就是宽字节字符集,它对每个字符都固定使用两个字节即16位表示,于是当处理字符时,不必担心只处理半个字符。

目前,Unicode在网络、Windows系统和很多大型软件中得到应用。

关于GB编码的一些常识

GB编码标准中,比较常用的是GB2312和GBK两种,GB2312是GBK的一个子集,GB2312编码范围是 0xA1A1 - 0xFEFE ,如果纯粹的 GB2312编码,处理起来是什分简单的,但处理GBK字符集时有些小的提示,先说说GBK编码的标准吧:

GBK 采用双字节表示,总体编码范围为 8140-FEFE,首字节在 81-FE 之间,尾字节在 40-FE 之间,剔除 xx7F 一条线。总计 23940 个码位,共收入 21886 个汉字和图形符号,其中汉字(包括部首和构件)21003 个,图形符号 883 个。

全部编码分为三大部分:

1 汉字区。包括:

a GB 2312 汉字区。即 GBK/2: B0A1-F7FE。收录 GB 2312 汉字 6763 个,按原顺序排列。

b GB 130001 扩充汉字区。包括:

(1) GBK/3: 8140-A0FE。收录 GB 130001 中的 CJK 汉字 6080 个。

(2) GBK/4: AA40-FEA0。收录 CJK 汉字和增补的汉字 8160 个。

CJK 汉字在前,按 UCS 代码大小排列;增补的汉字(包括部首和构件)在后,按《康熙字典》的页码/字位排列。

2 图形符号区。包括:

a GB 2312 非汉字符号区。即 GBK/1: A1A1-A9FE。其中除 GB 2312 的符号外,

还有 10 个小写罗马数字和 GB 12345 增补的符号。计符号 717 个。

b GB 130001 扩充非汉字区。即 GBK/5: A840-A9A0。BIG-5 非汉字符号、结构符和“○”排列在此区。计符号 166 个。

3 用户自定义区:分为(1)(2)(3)三个小区。

(1) AAA1-AFFE,码位 564 个。

(2) F8A1-FEFE,码位 658 个。

(3) A140-A7A0,码位 672 个。

第(3)区尽管对用户开放,但限制使用,因为不排除未来在此区域增补新字符的可能性。

这里有几个小技巧:

一、在php中,字符编码是按所发送的编码为准的,因些使用的就是用户输入的编码,不会自动改变,但在asp中,默认的编码是unicode,这样我们很容易就能得到gbk->unicode的编码对照表,这样即使在毫无基础库的情况下也能很容易的实现gbk到utf-8的转换了;

二、由于GBK是高位最低数值是0x40,即是64,因此,有时候组织一些涉及中文的字串时,分割字符最好用64之前的ascii码,这样在任意情况下替换或分割都不会出现乱码,比较常用的是 ","、";"、":"、" "、" "、" ",这些字符永远都不会给gb编码添乱。

字符集编码转换轻松实现

一、利用iconv函数族进行编码转换

在LINUX上进行编码转换时,既可以利用iconv函数族编程实现,也可以利用iconv命令来实现,只不过后者是针对文件的,即将指定文件从一种编码转换为另一种编码。

iconv函数族的头文件是iconvh,使用前需包含之。

#include <iconvh>

iconv函数族有三个函数,原型如下:

(1) iconv_t iconv_open(const char tocode, const char fromcode);

此函数说明将要进行哪两种编码的转换,tocode是目标编码,fromcode是原编码,该函数返回一个转换句柄,供以下两个函数使用。

(2) size_t iconv(iconv_t cd,char inbuf,size_t inbytesleft,char outbuf,size_t outbytesleft);

此函数从inbuf中读取字符,转换后输出到outbuf中,inbytesleft用以记录还未转换的字符数,outbytesleft用以记录输出缓冲的剩余空间。 (3) int iconv_close(iconv_t cd);

此函数用于关闭转换句柄,释放资源。

例子1: 用C语言实现的转换示例程序

/ fc :代码转换示例C程序 /

#include <iconvh>

#define OUTLEN 255

main()

{

char in_utf8 = "姝eㄥ瑁";

char in_gb2312 = "正在安装";

char out[OUTLEN];

//unicode码转为gb2312码

rc = u2g(in_utf8,strlen(in_utf8),out,OUTLEN);

printf("unicode-->gb2312 out=%sn",out);

//gb2312码转为unicode码

rc = g2u(in_gb2312,strlen(in_gb2312),out,OUTLEN);

printf("gb2312-->unicode out=%sn",out);

}

//代码转换:从一种编码转为另一种编码

int code_convert(char from_charset,char to_charset,char inbuf,int inlen,char outbuf,int outlen)

{

iconv_t cd;

int rc;

char pin = &inbuf;

char pout = &outbuf;

cd = iconv_open(to_charset,from_charset);

if (cd==0) return -1;

memset(outbuf,0,outlen);

if (iconv(cd,pin,&inlen,pout,&outlen)==-1) return -1;

iconv_close(cd);

return 0;

}

//UNICODE码转为GB2312码

int u2g(char inbuf,int inlen,char outbuf,int outlen)

{

return code_convert("utf-8","gb2312",inbuf,inlen,outbuf,outlen);

}

//GB2312码转为UNICODE码

int g2u(char inbuf,size_t inlen,char outbuf,size_t outlen)

{

return code_convert("gb2312","utf-8",inbuf,inlen,outbuf,outlen);

}

例子2: 用C++语言实现的转换示例程序

/ fcpp : 代码转换示例C++程序 /

#include <iconvh>

#include <iostream>

#define OUTLEN 255

using namespace std;

// 代码转换 *** 作类

class CodeConverter {

private:

iconv_t cd;

public:

// 构造

CodeConverter(const char from_charset,const char to_charset) {

cd = iconv_open(to_charset,from_charset);

}

// 析构

~CodeConverter() {

iconv_close(cd);

}

// 转换输出

int convert(char inbuf,int inlen,char outbuf,int outlen) {

char pin = &inbuf;

char pout = &outbuf;

memset(outbuf,0,outlen);

return iconv(cd,pin,(size_t )&inlen,pout,(size_t )&outlen);

}

};

int main(int argc, char argv)

{

char in_utf8 = "姝eㄥ瑁";

char in_gb2312 = "正在安装";

char out[OUTLEN];

// utf-8-->gb2312

CodeConverter cc = CodeConverter("utf-8","gb2312");

ccconvert(in_utf8,strlen(in_utf8),out,OUTLEN);

cout << "utf-8-->gb2312 in=" << in_utf8 << ",out=" << out << endl;

// gb2312-->utf-8

CodeConverter cc2 = CodeConverter("gb2312","utf-8");

cc2convert(in_gb2312,strlen(in_gb2312),out,OUTLEN);

cout << "gb2312-->utf-8 in=" << in_gb2312 << ",out=" << out << endl;

}

二、利用iconv命令进行编码转换

在LINUX上进行编码转换时,既可以利用iconv函数族编程实现,也可以利用iconv命令来实现,只不过后者是针对文件的,即将指定文件从一种编码转换为另一种编码。

iconv命令用于转换指定文件的编码,默认输出到标准输出设备,亦可指定输出文件。

用法: iconv [选项] [文件]

有如下选项可用:

输入/输出格式规范:

-f, --from-code=名称 原始文本编码

-t, --to-code=名称 输出编码

信息:

-l, --list 列举所有已知的字符集

输出控制:

-c 从输出中忽略无效的字符

-o, --output=FILE 输出文件

-s, --silent 关闭警告

--verbose 打印进度信息

-, --help 给出该系统求助列表

--usage 给出简要的用法信息

-V, --version 打印程序版本号

例子:

iconv -f utf-8 -t gb2312 aaatxt >bbbtxt

这个命令读取aaatxt文件,从utf-8编码转换为gb2312编码,其输出定向到bbbtxt文件。

小结: LINUX为我们提供了强大的编码转换工具,给我们带来了方便。

以上就是关于icd编码43.81什么时候使用全部的内容,包括:icd编码43.81什么时候使用、Python-lesson 2 数据类型、字符编码、文件处理、常常听人说"编码".怎么解释.等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9773642.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存