# -*- coding: utf-8 -*-
# Python 版本需要為 3.5 以上
first_names = ('李', '王', '司', '司馬')
def name_parser(name, first_name_count=1):
"""
分析姓名,返回姓和名的元組
:param str name: 姓名
:param int first_name_count: 姓氏長度,默認為1
:return: 姓和名的元組,如果沒分析成功就返回空元組
:rtype: tuple
"""
if name[0:first_name_count] in first_names:
return (name[0:first_name_count], name[first_name_count:])
else:
return ()
if __name__ == '__main__':
# name.txt 需要為 UTF-8 編碼,如果為其他編碼,自行優化處理
with open('name.txt', 'r', encoding='utf-8') as f:
for i in f:
name = i.rstrip('\n')
# 最多嘗試兩字的姓
for n in range(1, 3):
s = name_parser(name, n)
if s:
print('{} 的姓氏為: {},名字為: {}.'.format(name, s[0], s[1]))
break
else:
print('未分析出 {} 的姓氏和名字,可能需要補充姓氏列表.'.format(name))