因此,我基本上要求我有一个名称,我需要将它分成三个部分,并使用Python将其存储到三个不同的变量中。
例如:
Name=“约翰·韦恩·史密斯”
那么所需的输出应该是:
第一name=约翰
中间Name=韦恩
姓=史密斯
另外,我想检查一下,如果某个人的中间名不存在,那么它应该是空的。
发布于 2020-10-26 11:07:34
使用拆分函数创建具有名称的列表,第一个是名称,第二个是您的姓氏,如果名称长度等于2时
names =Name.split()
if len(names) ==2 :
print("there is no middle name")
first_name = names[0]
last_name = names[1]
print(f" first name - {first_name}\n middle name - last name - {last_name}")
elif len(names) == 3:
print("there is middle name")
first_name = names[0]
middle_name = names[1]
last_name = names[2]
print(f" first name - {first_name}\n middle name - {middle_name} \nlast name - {last_name}")发布于 2022-02-21 07:03:33
库名称解析是解决您的问题的完美解决方案。你可以通过
pip安装名称解析器
在您的代码中,将此库导入为:
from nameparser import HumanName
name = "John Wayne Smith"
name_parts = HumanName(name)
name_parts.title
name_parts.first
name_parts.middle
name_parts.last
name_parts.suffix
name_parts.nickname
name_parts.surnames # (middle + last)
name_parts.initials # (first initial of each name part)发布于 2020-10-26 11:08:37
我们可以使用以下正则表达式:
(?P<First>\S+)\s(?:(?P<Middle>\S*)\s)?(?P<Last>\S+)$它寻找一个名字和姓氏,也可以选择一个中间名。
示例
import re
s = "John Wayne Smith"
s2 = "John Smith"
p = re.compile(r"(?P<First>\S+)\s(?:(?P<Middle>\S*)\s)?(?P<Last>\S+)$")p.match(s).groupdict()
# {'First': 'John', 'Middle': 'Wayne', 'Last': 'Smith'}
p.match(s2).groupdict()
# {'First': 'John', 'Middle': None, 'Last': 'Smith'}请注意,match将从开始到结束匹配整个字符串。请确保事先清理和验证您的输入,因为正则表达式对于他们不期望的输入有些易碎。
https://stackoverflow.com/questions/64535868
复制相似问题