加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

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

发布时间:2020-12-20 12:57:16 所属栏目:Python 来源:网络整理
导读:下边代码段是关于一个将汉字转换成汉语拼音的python库的代码。 #!/usr/bin/env python """ Author:cleverdeng E-mail:[email?protected] """ __version__ = ‘0.9‘ __all__ = ["PinYin"] import os.path class PinYin(object): def __init__(self,dict_file

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

"""
Author:cleverdeng
E-mail:[email?protected]
"""

__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>

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读