码迷,mamicode.com
首页 > 编程语言 > 详细

Python任意字符集转换

时间:2018-06-20 11:15:38      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:一个   charset   ret   content   return   TE   cto   lang   data   

在python处理文本的过程中,经常会有文本字符集转换的情况,
而我们希望用一个方法,不用关心文本原本的字符集是什么样的,直接转换成想要的任何字符集就可以了。

方法一:

import chardet  
def convert_encoding(data,new_coding=‘UTF-8‘):
  # 任意字符集转换
  encoding = chardet.detect(data)[‘encoding‘]
  if new_coding.upper() != encoding.upper():
    data  = data.decode(encoding,data).encode(new_coding)
  return data 

方法二:

import icu  
def convert_encoding2(data,new_coding=‘UTF-8‘):

  encoding = icu.CharsetDetector(data).detect().getName()  
  # encoding = chardet.detect(content)[‘encoding‘]
  if new_coding.upper() != encoding.upper():
    # data  = data.decode(encoding,data).encode(new_coding)
    data = unicode(data,coding).encode(new_coding)
  return data 

方法三:

import cchardet
def convert_encoding3(data,new_coding=‘UTF-8‘):
  encoding = cchardet.detect(data)[‘encoding‘]
  if new_coding.upper() != encoding.upper():
    data  = data.decode(encoding,data).encode(new_coding)
  return data 

使用方法:

此处使用方法一

#转换成utf-8
convert_encoding(data,‘utf-8‘)

#转抱成GBK  
convert_encoding(data,‘gbk‘)

#转抱成GB2312
convert_encoding(data,‘gbk‘)

Python任意字符集转换

标签:一个   charset   ret   content   return   TE   cto   lang   data   

原文地址:http://blog.51cto.com/yangrong/2130811

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!