我在按照列出的顺序,姓名和考试成绩来分配我的名字时遇到了问题。
我在代码中执行了以下操作:print repr(names)
在循环中获取以下6行数据
'1 Name 559/1 '
'2 Name 484/1 '
'3 Name N'ame 444/2 '
'4 Name 400/1 '
'5 Name Name 928/5 '
'6 Name Name-Name 1292/10 '
我希望能够将它们分开但我收到错误AttributeError: 'str' object has no attribute 'lsplit'
我曾经使用过lsplit,rsplit和split,但我无法让它工作......
最后,结果名称将变为3个变量:names_index
,name
和names_score
任何人都知道如何实现这一目标吗?
谢谢 - Hyflex
修改
for item in listitems:
if item.find("strong"):
names = str(item.text)
names = items .split("\n")
for name in names:
clean_name = name.lstrip(" ")
print repr(clean_name)
student_number = clean_name.lsplit(" ", 1)
student_score = clean_name.rsplit(" ", 1)
#student_name = clean_name.lsplit(" ", 1) # Unsure how to get the last part..
答案 0 :(得分:6)
没有str.lsplit
因为str.split
已经从左边开始了。
对于每个字符串,只需致电.split()
,您将获得一个包含[names_index, name, names_score]
如果模式为number / words / more numbers
,则可以使用正则表达式:
>>> import re
>>> filter(None, re.split(r'(\d+) (\w.*) (\d.*)', '1 Name 559/1 '))
['1', 'Name', '559/1 ']
>>> filter(None, re.split(r'(\d+) (\w.*) (\d.*)', '6 Name Name-Name 1292/10 '))
['6', 'Name Name-Name', '1292/10 ']
答案 1 :(得分:3)
rsplit返回拆分结果,而不仅仅是最后一部分。所以你实际上正朝着正确的方向前进。
对于您的名字中可能有空格的代码,您可以这样做:
the_string = the_string.strip()
[id, name_score] = the_string.split(' ',1) # Split into ['1', 'name name 654/1']
[name, score] = name_score.rsplit(' ',1) # Split into ['name name','654/1']
因此,对于输入“6 Name Name-Name 1292/10”,您的预期值已经存在:
id # this is '6'
name # this is 'Name Name-name'
score # this is '1292/10'
答案 2 :(得分:3)
就像 -
一样简单>>> s = '4 Name 400/1 '
>>> names_index, name, names_score = s.split()
>>> names_index, name, names_score
('4', 'Name', '400/1')
>>>
正如Haidro所说,lsplit没有任何功能,而是使用split。
答案 3 :(得分:3)
您可以使用列表
进行操作>>> names = ['1 Name 559/1 ',
'2 Name 484/1 ',
'3 Name Naaame 444/2 ',
'4 Name 400/1 ',
'5 Name Name 928/5 ',
'6 Name Name-Name 1292/10 ']
>>> names_lst=[]
>>> for n in names:
names_lst+=n.split()
给出
>>> names_lst
['1', 'Name', '559/1', '2', 'Name', '484/1', '3', 'Name', 'Naaame',
'444/2', '4', 'Name', '400/1', '5', 'Name', 'Name', '928/5', '6', 'Name',
'Name-Name', '1292/10', ['1', 'Name', '559/1'], ['2', 'Name', '484/1'],
['3', 'Name', 'Naaame', '444/2'], ['4', 'Name', '400/1'],
['5', 'Name', 'Name', '928/5'], ['6', 'Name', 'Name-Name', '1292/10']]