python - 文本处理 之 解码编码decode encode

目录

1.decode解码

2.encode编码

3.特殊符号

4.常用操作

(1)字符串编码常用类型

(2)gb2312转为utf-8

(3)转码异常

(4)u'string'指定unicode类型

(5)r'string'禁止转义

(6)字符串转为二进制

(7)二进制转成字符串


1.decode解码

python3后,字符串在Python内部为unicode编码,因此解码为将其他编码转成unicode

(1)语法参数

用于将 bytes 类型的二进制数据转换为 str 类型,这个过程也称为“解码”

语法:str.decode(encoding='UTF-8',errors='strict')

encoding -- 使用的编码,utf-8,gb2312,cp936,gbk。

errors -- 异常处理方案'ignore', 'replace', 'xmlcharrefreplace', 'backslashreplace'等

(2)decode例子

s.decode("utf-8", "ignore") 忽略其中有异常的编码

s.decode("utf-8", "replace") 替换其中异常的编码

#以gb2312编码对字符串str进行解码,以获取unicode u1 = str.decode('gb2312')

2.encode编码

(1)语法参数

encode用于将 str 类型转换成 bytes 类型,这个过程也称为“编码”

语法:str.encode(encoding='UTF-8',errors='strict')

encoding -- 使用的编码,utf-8,gb2312,cp936,gbk。

errors -- 异常处理方案'ignore', 'replace', 'xmlcharrefreplace', 'backslashreplace'等

(2)encode例子

str = "this is string example....wow!!!";

print("Encoded String: " + str.encode('base64','strict'))

3.特殊符号

(1)特殊符号介绍

回车符(\r)、换行符(\n)、水平制表符(\t)、垂直制表符(\v)、换页符(\f))    

(2)去掉特殊符号

"   xyz   ".strip()           #去掉前后空格

s.replace('\t','|')    #替换制表符

s.strip('\n') #去掉前后换行符

s.replace("\n", "") #替换换行符 

(3)转义字符

反斜杠是转义字符,必须用两个反斜杠'\\'来表示反斜杠

两个反斜杠就要用四个反斜杠来表示'\\\\'

a=r'F:\百度云同步盘\Buyerid/SmartOmi buyer id &order id 201611.1-2016.12.31.txt'

b=a.replace('\\','/')

4.常用操作

(1)字符串编码常用类型

utf-8,gb2312,cp936,gbk

(2)gb2312转为utf-8

s.decode('gb2312').encode('utf-8')

(3)转码异常

s.decode('gbk', 'ignore').encode('utf-8')

(4)u'string'指定unicode类型

在python2k中u表示unicode string,类型是unicode, 没有u表示byte string,类型是 str。

在python3中所有字符串都是unicode string, u前缀没有特殊含义了。

(5)r'string'禁止转义

字符串前面加r,表示的意思是禁止字符串转义,说明字符串r"XXX"中的XXX是普通字符。

(6)字符串转为二进制

encode用于字符串类型转换为二进制类型

s1='apple'

s2=s1.encode('utf-8')

print(s2)

#b'apple'

(7)二进制转成字符串

s1=b'apple'

s2=s1.decode('utf-8')

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Python中的字符串编码解码可以通过encode()和decode()方法来实现。这两个方法都是字符串对象的方法,用于将字符串从一种编码格式转换为另一种编码格式。 encode()方法可以将字符串编码为指定的编码格式,其语法为: ```python string.encode(encoding=编码格式, errors=错误处理) ``` 其中,encoding参数是必须的,用于指定要使用的编码格式,errors参数是可选的,用于指定错误处理方式。如果不指定errors参数,则默认使用strict模式,即如果存在无法编码的字符,则会抛出UnicodeError异常。 例如,将一个字符串编码UTF-8格式: ```python string = "Hello World" encoded_string = string.encode(encoding="utf-8") print(encoded_string) ``` 输出结果为:b'Hello World'。其中,b表示这是一个字节串对象,而不是字符串对象。 decode()方法可以将字节串解码为指定的编码格式,其语法为: ```python bytes.decode(encoding=编码格式, errors=错误处理) ``` 其中,encoding参数是必须的,用于指定要使用的编码格式,errors参数是可选的,用于指定错误处理方式。如果不指定errors参数,则默认使用strict模式,即如果存在无法解码的字节,则会抛出UnicodeError异常。 例如,将一个UTF-8格式的字节串解码为字符串: ```python bytes_string = b'Hello World' decoded_string = bytes_string.decode(encoding="utf-8") print(decoded_string) ``` 输出结果为:Hello World。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值