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 panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

Python操作PDF文档的主流库使用指南

《Python操作PDF文档的主流库使用指南》PDF因其跨平台、格式固定的特性成为文档交换的标准,然而,由于其复杂的内部结构,程序化操作PDF一直是个挑战,本文主要为大家整理了Python操作PD... 目录一、 基础操作1.PyPDF2 (及其继任者 pypdf)2.PyMuPDF / fitz3.Fre

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统