首页 > 编程语言 > 详细

一个将汉字转换成汉语拼音的python库的代码

时间:2019-07-24 22:36:11      阅读:155      评论:0      收藏:0      [点我收藏+]

下边代码段是关于一个将汉字转换成汉语拼音的python库的代码。
#!/usr/bin/env python

"""
Author:cleverdeng
E-mail:clverdeng@gmail.com
"""

__version__ = ‘0.9‘
__all__ = ["PinYin"]

import os.path


class PinYin(object):
def __init__(self, dict_file=‘word.data‘):
self.word_dict = {}
self.dict_file = dict_file


def load_word(self):
if not os.path.exists(self.dict_file):
raise IOError("NotFoundFile")

with file(self.dict_file) as f_obj:
for f_line in f_obj.readlines():
try:
line = f_line.split(‘ ‘)
self.word_dict[line[0]] = line[1]
except:
line = f_line.split(‘ ‘)
self.word_dict[line[0]] = line[1]


def hanzi2pinyin(self, string=""):
result = []
if not isinstance(string, unicode):
string = string.decode("utf-8")

for char in string:
key = ‘%X‘ % ord(char)
result.append(self.word_dict.get(key, char).split()[0][:-1].lower())

return result


def hanzi2pinyin_split(self, string="", split=""):
result = self.hanzi2pinyin(string=string)
if split == "":
return result
else:
return split.join(result)


if __name__ == "__main__":
test = PinYin()
test.load_word()
string = "钓鱼岛是中国的"
print "in: %s" % string
print "out: %s" % str(test.hanzi2pinyin(string=string))
print "out: %s" % test.hanzi2pinyin_split(string=string, split="-")



<h4>附件:<a href="/uploadfiles/2013/06/20/13717130117510.zip">源代码下载</a></h4>


 

一个将汉字转换成汉语拼音的python库的代码

原文:https://www.cnblogs.com/fulhns/p/11241287.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!