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绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

python 字典d[k]中key不存在的解决方案

《python字典d[k]中key不存在的解决方案》本文主要介绍了在Python中处理字典键不存在时获取默认值的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录defaultdict:处理找不到的键的一个选择特殊方法__missing__有时候为了方便起见,

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画

Python pyinstaller实现图形化打包工具

《Pythonpyinstaller实现图形化打包工具》:本文主要介绍一个使用PythonPYQT5制作的关于pyinstaller打包工具,代替传统的cmd黑窗口模式打包页面,实现更快捷方便的... 目录1.简介2.运行效果3.相关源码1.简介一个使用python PYQT5制作的关于pyinstall

使用Python实现大文件切片上传及断点续传的方法

《使用Python实现大文件切片上传及断点续传的方法》本文介绍了使用Python实现大文件切片上传及断点续传的方法,包括功能模块划分(获取上传文件接口状态、临时文件夹状态信息、切片上传、切片合并)、整... 目录概要整体架构流程技术细节获取上传文件状态接口获取临时文件夹状态信息接口切片上传功能文件合并功能小

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主