>>> itms="""banana cookie cream soda lime limes apples
desert plate cake orange milk beans
juice apple pie"""
我想知道你如何计算多行字符串中某一行中的项目?
示例:第一行将返回 7
第二个将返回 6
最后一个将返回 2 (由于"苹果派"它之间只包含1个空白区域。)
答案 0 :(得分:2)
In [12]: itms="""banana cookie cream soda lime limes apples
...: desert plate cake orange milk beans
...: juice apple pie"""
将字符串拆分为行
In [13]: itms = [line.strip() for line in itms.split('\n')]
In [14]: itms
Out[14]:
['banana cookie cream soda lime limes apples',
'desert plate cake orange milk beans',
'juice apple pie']
将项目分成两个以上的空格
In [15]: import re
In [16]: itms = [re.split(r'\s\s+', line) for line in itms]
In [17]: itms
Out[17]:
[['banana', 'cookie', 'cream', 'soda', 'lime', 'limes', 'apples'],
['desert', 'plate', 'cake', 'orange', 'milk', 'beans'],
['juice', 'apple pie']]
计算每行中的元素
In [18]: for x in itms:
...: print(len(x))
...:
7
6
2
答案 1 :(得分:2)
假设您可以指望divider一词总是两个空格,以下内容将返回[7, 6, 2]
:
[len(line.strip().split(' ')) for line in itms.split('\n')]
如果单词divider是任意数量的空白字符,则可以使用正则表达式模块。
import re
[len(re.split(r'\s\s+', line.strip())) for line in itms.split('\n')]
答案 2 :(得分:1)
这是一个小例子,打印出一行中的元素数量。
import re
lines = [re.split(r'\s{2,}',x.strip()) for x in itms.split("\n")]
for index, line in enumerate(lines):
print "line number : {0} has {1} elements".format(index, len(line))
line number : 0 has 7 elements
line number : 1 has 6 elements
line number : 2 has 3 elements
1)首先,您要将每个line
字符串放入strings
2)然后将其分解为单个元素,以便一行中的每个单词都在其自己的列表中。
3)从那以后,我们只需得到包含your words per line
的列表的长度。
答案 3 :(得分:0)
您可以使用两行代码:
it = itms.split('\n')
for i in it: print(len(i.split()))