jcpython2 发表于 2022-10-9 19:59:12

记录输出元素中某元素出现位置

这是我解题中的其中一个功能需求,以下是我写的代码,目标应该输出记录了3次ab位置的list但最后只输出

a,b= 'aaabbbbbabcab','ab'
j = 0
total = []
k = 0
for j in range(len(a)):
    if a.find(b,k,14) != -1:
      total.append(a.find(b,k,14))
      k = k + a.find(b,k,14) +1
    j += 1   
print(total)


代码中13是a的长度,为了易读所以直接写了13,

k = k + a.find(b,k,13) +1

第八行代码,虽然是我写的,但是最后的那个+1 我感觉会容易出bug?,但不写+1我不知道这个find的下标什么方法迭代上去好

jackz007 发表于 2022-10-9 20:07:44

本帖最后由 jackz007 于 2022-10-9 20:31 编辑

      循环应该以找完所有的目标子串为原则进行驱动
a , b= 'aaabbbbbabcab','ab'
j = 0
total = []
while True:
    j = a . find(b , j)
    if j >= 0:
      total . append(j)
      j += len(b)
    else:
      break
print(total)
       不用 find() 似乎能简单些:
a , b , i , total = 'aaabbbbbabcab' , 'ab' , 0 , []
while i < len(a) - len(b) + 1:
    if a == b :
      total . append(i)
      i += len(b) - 1
    i += 1
print(total)
       运行实况:
D:\\Python>python x.py


D:\\Python>

jcpython2 发表于 2022-10-9 20:26:45

jackz007 发表于 2022-10-9 20:07
循环应该以找完所有的目标字串为原则进行驱动

       运行实况:

我以为find写了起始就必须写结束位置呢,

你这个while true 可以这样写我未曾看过这种写法

思路是j = a . find(b , j)
    if j >= 0:
      total . append(j)
      j += len(b)
这段一旦出错就会马上跳到整个循环的else吗?
因为我一般用while都是加了判断 i < x然后循环中迭代i直到while为 false

jackz007 发表于 2022-10-9 20:28:12

本帖最后由 jackz007 于 2022-10-9 20:30 编辑

jcpython2 发表于 2022-10-9 20:26
我以为find写了起始就必须写结束位置呢,

你这个while true 可以这样写我未曾看过这种写法


       不会出错,如果找到了子串,j 的值是正值或0值,如果没有找到,j 的值就是 -1

jcpython2 发表于 2022-10-9 20:35:20

jackz007 发表于 2022-10-9 20:28
不会出错,如果找到了子串,j 的值是正值或0值,如果没有找到,j 的值就是 -1

我刚才说错了,我现在理解了代码
原理就是find到最后会出现-1触发break才对

jackz007 发表于 2022-10-9 20:37:21

jcpython2 发表于 2022-10-9 20:35
我刚才说错了,我现在理解了代码
原理就是find到最后会出现-1触发break才对

       Bingo ,就是这个意思!

jcpython2 发表于 2022-10-9 23:20:17

更新一个刚写的有效代码,弄懂find可以返回-1和字符串下标不用写结束后,整体简洁明了了很多
a,b= 'ababcdefgabdefab','ab'
fi = a.find(b)
list = []
while fi != -1:
    list.append(fi)
    fi = a.find(b,fi+len(b))
print(list)
页: [1]
查看完整版本: 记录输出元素中某元素出现位置