python 学习汇总41:unicode( tcy)

2024-03-20 09:58
文章标签 python 学习 41 汇总 unicode tcy

本文主要是介绍python 学习汇总41:unicode( tcy),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Unicode   2018/7/1

1.字符一般字符:'a';'严';
特殊字符:
编辑器中不能直接输入,在字符串文字中使用转义序列
\u转义序列编写特定的Unicode代码点'\u0394' # 'Δ' 16-bit hex value
"\U00000394 # 'Δ' 32-bit hex value
"\N{GREEK CAPITAL LETTER DELTA}" # 希腊大写字母Delta :'Δ'
répertoire = "trouvé" #可将Unicode字符包含在字符串文字,标识符中。
2.Unicode
2.1. 字符集:
只是一个“字符集”,它给每一个处于此字符集中的字符给予了一个编号。
Unicode 标准描述了如何用 代码点 表示字符。代码点是一个整数值通常用16 进制表示。
Unicode标准包含很多列出字符及其相应代码点的表格:0061 'a'; LATIN SMALL LETTER A
0062 'b'; LATIN SMALL LETTER B
0063 'c'; LATIN SMALL LETTER C
...
007B '{'; LEFT CURLY BRACKET一个Unicode字符串是一系列代码点,从0到0x10FFFF的数字。
该序列需要表示为内存中的一组字节(意思是从0到255的值)。
将Unicode字符串转换为字节序列的规则称为编码。
        ord('a')                                            # 97hex(ord("严"))= '0x4e25'                #"严"unicode代码点=4E25ord('\u0394')   #等价于:ord('Δ')    #返回代码点值:=916逆转换:chr(916)        #等价于:chr(0x394) #10进制的916=16进制的394 #返回单字符'Δ'chr(97)          #等价于:chr(0x61)   #10进制的97=16进制的61     #返回单字符'a'
   2.2.编码方案 utf-8指定字符以什么字节序存储和传输将Unicode字符串转换为字节序列的规则称为编码。编码一定,字节序一定,存储结果是肯定要落实到字节(Bytes)上来的。
     编码:'a'.encode('utf-8')         # b'a' 返回Unicode字符串的bytes"严".encode()              #b'\xe4\xb8\xa5''Δ'.encode('utf-8')        # b'\xce\x94'解码:b'a'.decode()                      # 'a'b'\xe4\xb8\xa5'.decode()  #"严"b'\xce\x94'.decode()         # 'Δ' 
3.指定代码编码:代码前2行
# -*- coding: <encoding name> -*-
获取系统编码:
import sys
sys.getfilesystemencoding()# 'utf-8
4.实例:
实例1.-编码str.encode()
str.encode            返回Unicode字符串的bytes参数:strictignorereplace                  插入问号xmlcharrefreplace  插入XML字符引用backslashreplace   插入\uNNNN转义序列namereplace          插入\N实例:u = chr(40960) + 'abcd' + chr(1972)u.encode('utf-8')                                     # b'\xea\x80\x80abcd\xde\xb4'u.encode('ascii')                                     #错误u.encode('ascii', 'ignore')                      # b'abcd'u.encode('ascii', 'replace')                    # b'?abcd?'u.encode('ascii', 'xmlcharrefreplace') # b'&#40960;abcd&#1972;'u.encode('ascii', 'backslashreplace')  # b'\\ua000abcd\\u07b4'u.encode('ascii', 'namereplace')          # b'\\N{YI SYLLABLE IT}abcd\\u07b4'
实例2.-解码bytes.decode()b'\x80abc'.decode("utf-8", "strict")                      #错误b'\x80abc'.decode("utf-8", "replace")                  # '\ufffdabc'b'\x80abc'.decode("utf-8", "backslashreplace") # '\\x80abc'b'\x80abc'.decode("utf-8", "ignore")                    #'abc'
实例3-ord(),chr():ord() #接受一个字符的Unicode字符串并返回代码点值以一个字符(长1字符串8位)作为参数,返回对应的 ASCII值或Unicode值如给Unicode字符超出范围引发TypeErrorchr()#用一字节整数作参数返回对应字符。创建单字符Unicode字符串,该函数使用整数并返回包含相应代码点的长度为1的Unicode字符串。chr(57344)   # '\ue000'ord('\ue000')# 57344
5.备注:
5.1.Unicode属性
字符信息包括字符的名称,类别,数值
# 显示一些关于几个字符的信息,并打印一个特定字符的数字值:
import unicodedatau = chr(233) + chr(0x0bf2) + chr(3972) + chr(6000) + chr(13231)
for i, c in enumerate(u):
print(i, '代码点=%04x ;代码=' % ord(c), unicodedata.category(c), end=" ")#类别代码:是描述角色性质的缩写。
print('; 名称=',unicodedata.name(c))
# Get numeric value of second character
print(unicodedata.numeric(u[1]))#1000.0# 0 代码点=00e9 ;代码= Ll ; 名称= LATIN SMALL LETTER E WITH ACUTE# 'Ll'意思是“Letter,小写”
# 1 代码点=0bf2 ;代码= No ; 名称= TAMIL NUMBER ONE THOUSAND# 'No'意思是“Number,other”
# 2 代码点=0f84 ;代码= Mn ; 名称= TIBETAN MARK HALANTA# 'Mn'是“Mark,nonspacing”
# 3 代码点=1770 ;代码= Lo ; 名称= TAGBANWA LETTER SA
# 4 代码点=33af ;代码= So ; 名称= SQUARE RAD OVER S SQUARED# 'So'是“Symbol,other”===================================================================
5.2.Unicode正则表达式
re模块支持的正则表达式可以以字节或字符串的形式提供。\d将匹配[0-9]字节中的字符,但字符串中的字符将匹配该'Nd'类别中的任何字符
\w匹配各种各样的Unicode字符,但只能[a-zA-Z0-9_]以字节或如果re.ASCII提供
\s并将匹配Unicode空白字符或 。[ \t\n\r\f\v]import re
p = re.compile(r'\d+')
s = "Over \u0e55\u0e57 57 flavours"
m = p.search(s)
print(repr(m.group()))
===================================================================
5.3.读写Unicode数据
open('unicode.txt', encoding='utf-8')
Unicode字符U+FEFF用作字节顺序标记(BOM),通常写为文件的第一个字符,以帮助自动检测文件的字节排序。Unicode文件名
filename = 'filename\u4500abc'
open(filename, 'w')
            os模块中的函数os.stat()也将接受Unicode文件名。该os.listdir()函数返回文件名# utf-8 返回Unicode版本的文件名,返回包含编码版本的字节。fn = 'filename\u4500abc'f = open(fn, 'w')f.close()import osprint(os.listdir(b'.'))print(os.listdir('.'))#输出:amk:~$ python t.py[b'filename\xe4\x94\x80abc', ...]#包含UTF-8编码的文件名['filename\u4500abc', ...]            #第二个列表包含Unicode版本注意在大多数情况下,应使用Unicode API。字节API只能用于不可解码文件名的系统,例如Unix系统。
====================================================================
5.4.编写支持Unicode的程序的技巧在文件编码之间转换StreamRecoder类可以在编码之间透明转换# 例如输入文件f是Latin-1,返回以UTF-8编码字节:new_f = codecs.StreamRecoder(f,# en/decoder: used by read() to encode its results and by write() to decode its input.codecs.getencoder('utf-8'), codecs.getdecoder('utf-8'),# reader/writer: used to read and write to the stream.codecs.getreader('latin-1'), codecs.getwriter('latin-1') )未知编码中的文件对文件进行更改不知道文件编码,知道编码与ASCII兼容,并只想检查或修改ASCII部分,用surrogateescape错误处理程序打开该文件:with open(fname, 'r', encoding="ascii", errors="surrogateescape") as f:data = f.read()# make changes to the string 'data'with open(fname + '.new', 'w',encoding="ascii", errors="surrogateescape") as f:f.write(data)surrogateescape错误处理程序将所有非ASCII字节解码为Unicode的专用使用区域范围从U + DC80到U + DCFF代码点。surrogateescape当编码数据并将其写回时使用错误处理程序时,这些私有代码点将被重新转换为相同的字节。

 

这篇关于python 学习汇总41:unicode( tcy)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/829090

相关文章

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e