python - pandas:如何限制 str.contains 的结果?

标签 python performance pandas contains

我有一个超过 100 万行的 DataFrame。我想选择特定列包含特定子字符串的所有行:

matching = df['col2'].str.contains('substr', case=True, regex=False)
rows = df[matching].col1.drop_duplicates()

但是这个选择很慢,我想加快速度。假设我只需要前 n 个结果。有没有办法在得到 n 个结果后停止匹配?我试过:

matching = df['col2'].str.contains('substr', case=True, regex=False).head(n)

和:

matching = df['col2'].str.contains('substr', case=True, regex=False).sample(n)

但它们并没有更快。第二个语句是 bool 值并且非常快。我怎样才能加快第一个声明?

最佳答案

信不信由你,但 .str 访问器很慢。您可以使用具有更好性能的列表理解。

df = pd.DataFrame({'col2':np.random.choice(['substring','midstring','nostring','substrate'],100000)})

相等性测试

all(df['col2'].str.contains('substr', case=True, regex=False) ==
    pd.Series(['substr' in i for i in df['col2']]))

输出:

True

时间:

%timeit df['col2'].str.contains('substr', case=True, regex=False)
10 loops, best of 3: 37.9 ms per loop

对比

%timeit pd.Series(['substr' in i for i in df['col2']])
100 loops, best of 3: 19.1 ms per loop

关于python - pandas:如何限制 str.contains 的结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49306324/

相关文章:

google-app-engine - 将编码键映射到应用引擎中的较短标识符

python,对数字/字符串列表进行排序(将列表元素转换为序数值)

python - 具有多维数组的外积

c - 任何人都知道如何将巨大的 char 数组转换为 float,非常巨大的数组,性能比 atof/strtod/sscanf 更好

python - 如何在pygame中伪造鼠标事件?

c++ - std::bitset 的性能如何?

python - 将 df.groupby...max() 结果输入新列。 Pandas

python - 显示数据框时显示趋势箭头

python - Tensorflow:如何在应用程序中使用经过训练的模型?

python - 从雅虎财经论坛提取回复