如何解决根据索引获取列表中单词的字母索引
假设我有一个单词列表:
mockMvc.perform(multipart("/upload").file("file","example".getBytes()))
.andExpect(status().isOk())
.andDo(document("upload",RequestPartsSnippet.requestParts(
RequestPartDescriptor.partWithName("file").description("The file to upload"))
));
我得到一个索引i,比方说l = ['example','to','a','list','of','words']
。
我需要返回10
中包含第i个字符的单词中字母的索引,
因此在10的示例中,第10个元素(从零开始)是单词l
中的l
-我需要返回的是0,如{{1} }是单词中的第一个字母。
例如,对于i = 17,输出将为list
,因为17指向l
中的字母1
-和{中的o
索引{1}}是1。
我一直在尝试一种简单的方法来实现此目的,但我没有发现任何优雅的方法。
任何帮助将不胜感激!
我问了类似的问题,并在这里得到了很好的答案:
但是找不到在这里修改答案的好方法。
解决方法
您在上一个问题中接受的解决方案(找到单词)
c = count()
print(next(s for s in l for _,i in zip(s,c) if i == 10))
进行临时修改以解决您的新问题(在单词中找到索引):
c = count()
print(next(j for s in l for j,i in zip(range(len(s)),c) if i == 10))
,
解决方案可能比接受的解决方案简单得多(l
是您的语言欲望,i
是字母的索引):
from string import ascii_lowercase as alphabet
result = next((idx for idx,x in enumerate(l) if alphabet[i] in x),None)
您可以使用任何字母(在这种情况下,我使用了'abcdefghijklmnopqrstuvwxyz'
)。另外,为next
函数设置默认值也很重要,否则您可能会遇到异常。
l = ['example','to','a','list','of','words']
index = 10
fl = [(c[1],c[0],w[1],w[0]) for w in enumerate(l) for c in enumerate(w[1])]
print('char = ' + fl[index][0] +
',index in word = ' + str(fl[index][1]) +
',word = ' + fl[index][2])
# char = l,index in word = 0,word = list
如果只需要单词中的索引:
fl2 = [c[0] for w in enumerate(l) for c in enumerate(w[1])]
print('index in word = ' + str(fl2[index]))
# index in word = 0
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。