【问题标题】:Python counting multiple substringsPython计算多个子字符串
【发布时间】:2017-05-23 21:58:00
【问题描述】:

我正在尝试计算字母在字符串中出现的次数,所以我正在使用运行良好的 count() 函数,但是使用多个 count() 函数似乎很乏味,因为我正在尝试计算10+ 个字母。

def printer_error(s):
 #errorLetters = ('r','s','t','u','v','w','x','y','z')
 errorRate = s.count('o') + s.count('p') + s.count('q')


 print(errorRate)
 return 

printer_error('aaaxbbbbyyhwawiwjjjwwm')

我的第一次尝试是 s.count(errorLetters) 但失败了,因为 count() 函数不能接受元组或列表。

当前代码给了我想要的结果,但我仍然需要连接 errorLetters 变量中的其余那些注释掉的字母,是否有另一种方法可以做到这一点,而不涉及进行 20 多个连接?

【问题讨论】:

  • 当前列出的 errorRate 变量不计算任何内容,因为我想保持它按字母顺序排列,但我事先用 'w' 和 'y' 给它发了短信,得到了我想要的结果。
  • 很遗憾我们不能对 cme​​ts 投反对票。 @ewcz 提议不好,在循环中使用s.count 是不必要的低效。
  • @wim 很公平 ;) sum([1 if c in errorLetters else 0 for c in s])

标签: python optimization refactoring


【解决方案1】:

最好的方法只需要迭代一次s,即 O(n)。

标准库collections 模块提供了一个有用且高效的Counter 对象:

>>> s = 'aaaxbbbbyyhwawiwjjjwwm'
>>> errorLetters = ('r','s','t','u','v','w','x','y','z')
>>> from collections import Counter
>>> counts = Counter(s)
>>> sum(counts[k] for k in errorLetters)
8

【讨论】:

  • 有很多有用的库,这很好用
猜你喜欢
  • 2015-12-01
  • 2014-12-25
  • 2023-03-22
  • 2021-06-03
  • 1970-01-01
  • 2014-11-01
  • 1970-01-01
  • 2023-03-28
  • 1970-01-01
相关资源
最近更新 更多