在 Python 中查找逗号分隔列表中的第 N 个项目

Posted

技术标签:

【中文标题】在 Python 中查找逗号分隔列表中的第 N 个项目【英文标题】:Find Nth item in comma separated list in Python 【发布时间】:2014-12-23 02:35:03 【问题描述】:

我有一个大型 csv,其中包含不同长度的逗号分隔行。对另一组数据进行排序,我在循环中使用split(',') 来分隔字段,但这种方法要求每行具有相同数量的条目。有没有办法可以查看一行,并且与条目总数无关,只需拉出第 N 个项目?作为参考,我使用的方法仅适用于看起来像 AAA,BBB,CCC,DDD 的行

entry = 'A,B,C,D'

(a,b,c,d) = entry.split(',')
print a,b,c,d

但我想拉 A 和 C,即使它看起来像 A,B,C,D,E,F 或 A,B,C

【问题讨论】:

【参考方案1】:

使用列表而不是单独的变量。

values = entry.split(',')
print values[0], values[2]

【讨论】:

【参考方案2】:

只需使用一个列表:

xyzzy = entry.split(",");
print xyzzy[0], xyzzy[2]

但请注意,一旦您允许可变元素计数的可能性,您可能最好允许太少:

entry = 'A,B'
xyzzy = entry.split(",");
(a,c) = ('?','?')
if len(xyzzy) > 0: a = xyzzy[0]
if len(xyzzy) > 2: c = xyzzy[2]

print a, c

【讨论】:

【参考方案3】:

如果你不想索引结果,编写自己的函数来处理值太少或两个很多的情况并不难。虽然设置需要多几行代码,但优点是您可以为结果提供有意义的名称,而不是像results[0]results[2]这样的匿名名称。

def splitter(s, take, sep=',', default=None):
    r = s.split(sep)
    if len(r) < take:
       r.extend((default for _ in xrange(take - len(r))))
    return r[:take]

entry = 'A,B,C'
a,b,c,d = splitter(entry, 4)
print a,b,c,d  # --> A B C None

entry = 'A,B,C,D,E,F'
a,b,c,d = splitter(entry, 4)
print a,b,c,d  # --> A B C D

【讨论】:

以上是关于在 Python 中查找逗号分隔列表中的第 N 个项目的主要内容,如果未能解决你的问题,请参考以下文章

在逗号分隔的列表中查找经理

如何使用 sed/awk 替换逗号分隔字符串中的第 n 列/字段?

如何使用 LINQ 查找包含 2 个逗号分隔的字符串的匹配项

更新分隔行中的第 n 个元素 [unix 脚本]

jquery:获取逗号分隔列表中的前 X 个项目

Excel:查找所有匹配值并放在逗号分隔列表中?