python把中文转英文_Python 3.0_文本清洗之中文特殊符号转英文特殊符号及全角字符转半角字符...

在文本清洗的过程,特殊符号的不规范是比较麻烦的事情,所以需要把文本中的特殊符号按照统一的标准处理。以下代码的作用就是将中文的特殊符号统一转成英文的,以及将全角符号转换成半角符号。参考代码# -*- coding: GBK -*-

import re

def strQ2B(ustring):

"""中文特殊符号转英文特殊符号"""

#中文特殊符号批量识别

pattern = re.compile('[,。:“”【】《》?;、()‘’『』「」﹃﹄〔〕—·]')

#re.compile: 编译一个正则表达式模式,返回一个模式(匹配模式)对象。

#[...]用于定义待转换的中文特殊符号字符集

fps = re.findall(pattern, ustring)

#re.findall: 搜索string,以列表形式返回全部能匹配的子串。

#对有中文特殊符号的文本进行符号替换

if len(fps) > 0:

ustring = ustring.replace(',', ',')

ustring = ustring.replace('。', '.')

ustring = ustring.replace(':', ':')

ustring = ustring.replace('“', '"')

ustring = ustring.replace('”', '"')

ustring = ustring.replace('【', '[')

ustring = ustring.replace('】', ']')

ustring = ustring.replace('《', '<')

ustring = ustring.replace('》', '>')

ustring = ustring.replace('?', '?')

ustring = ustring.replace(';', ':')

ustring = ustring.replace('、', ',')

ustring = ustring.replace('(', '(')

ustring = ustring.replace(')', ')')

ustring = ustring.replace('‘', "'")

ustring = ustring.replace('’', "'")

ustring = ustring.replace('’', "'")

ustring = ustring.replace('『', "[")

ustring = ustring.replace('』', "]")

ustring = ustring.replace('「', "[")

ustring = ustring.replace('」', "]")

ustring = ustring.replace('﹃', "[")

ustring = ustring.replace('﹄', "]")

ustring = ustring.replace('〔', "{")

ustring = ustring.replace('〕', "}")

ustring = ustring.replace('—', "-")

ustring = ustring.replace('·', ".")

"""全角转半角"""

#转换说明:

#全角字符unicode编码从65281~65374 (十六进制 0xFF01 ~ 0xFF5E)

#半角字符unicode编码从33~126 (十六进制 0x21~ 0x7E)

#空格比较特殊,全角为 12288(0x3000),半角为 32(0x20)

#除空格外,全角/半角按unicode编码排序在顺序上是对应的(半角 + 0x7e= 全角),所以可以直接通过用+-法来处理非空格数据,对空格单独处理。

rstring = ""

for uchar in ustring:

inside_code = ord(uchar)

if inside_code == 12288: #全角空格直接转换

inside_code = 32

elif (inside_code >= 65281 and inside_code <= 65374): #全角字符(除空格)根据关系转化

inside_code -= 65248

rstring += chr(inside_code)

return rstring测试代码if __name__ == "__main__":

str = '这是一个,【个人】deboke'

str_q2b = strQ2B(str)

print(str)

print(str_q2b)测试结果

423516f675ebe4716d713c902207896c.png参考链接:

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值