วิธีการรับตำแหน่งของตัวละครในงูหลาม?


527

ฉันจะรับตำแหน่งของตัวละครภายในสตริงในไพ ธ อนได้อย่างไร?

คำตอบ:


697

มีสองวิธีสตริงนี้, และfind() index()ความแตกต่างระหว่างสองสิ่งนี้เกิดขึ้นเมื่อไม่พบสตริงการค้นหา find()ผลตอบแทน-1 และยกindex()ValueError

การใช้ find()

>>> myString = 'Position of a character'
>>> myString.find('s')
2
>>> myString.find('x')
-1

การใช้ index()

>>> myString = 'Position of a character'
>>> myString.index('s')
2
>>> myString.index('x')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: substring not found

จากคู่มือ Python

string.find(s, sub[, start[, end]])
กลับดัชนีต่ำสุดในsที่ substring ย่อยพบดังกล่าวที่ย่อยs[start:end]ที่มีอยู่ในเครือใน ผลตอบแทน-1จากความล้มเหลว ค่าเริ่มต้นสำหรับการเริ่มต้นและสิ้นสุดและการตีความค่าลบเป็นเช่นเดียวกับชิ้น

และ:

string.index(s, sub[, start[, end]])
กดไลค์find()แต่เพิ่มValueErrorเมื่อไม่พบสตริงย่อย


127

เพียงเพื่อความสมบูรณ์ถ้าคุณต้องการค้นหาตำแหน่งทั้งหมดของตัวละครในสตริงคุณสามารถทำสิ่งต่อไปนี้:

s = 'shak#spea#e'
c = '#'
print [pos for pos, char in enumerate(s) if char == c]

ซึ่งจะกลับมา [4, 9]


4
ใน python3 ฉันได้รับข้อผิดพลาดทางไวยากรณ์ - จะแก้ไขได้อย่างไร?
Sean

19
@Sean: คำสั่งพิมพ์ถูกลบ เหลือเพียงรูปแบบฟังก์ชั่น น่ารำคาญ แต่คำตอบคือเปลี่ยนบรรทัดสุดท้ายนั้นเป็น: print( [pos for pos, char in enumerate(s) if char == c])
เนท

3
foo = ( [pos for pos, char in enumerate(s) if char == c])จะวางfooพิกัดในรูปแบบรายการ ฉันพบว่ามีประโยชน์จริง ๆ
3nrique0

มันคือ 0 ดัชนี 0123 เทียบกับ 1234 ดังนั้นตำแหน่งจริงคือ 5, 10
3kstc

เร็วแค่ไหน? ถ้าใครใช้ np.arrays จะมีประสิทธิภาพเพิ่มขึ้นสำหรับ str ยาวหรือไม่?
Seb

49
>>> s="mystring"
>>> s.index("r")
4
>>> s.find("r")
4

"ลมแรง"

>>> for i,c in enumerate(s):
...   if "r"==c: print i
...
4

เพื่อรับสายอักขระย่อย

>>> s="mystring"
>>> s[4:10]
'ring'

1
ขอบคุณบอกฉันว่าเราจะได้รับสตริงย่อยของสตริงตามตำแหน่งที่ได้รับ ...
user244470

1
@ arung: เพื่อให้ได้ใช้สตริงย่อยหั่น: str[from:to]ที่ไหนfromและtoมีดัชนี
Eli Bendersky

s.find () return -1 หากไม่พบ substring
Evgenii

s.search () เพิ่ม ValueError เมื่อไม่พบสตริงย่อย s.find () ส่งคืน -1 หากไม่พบสตริงย่อย
Praxiteles

16

เพื่อให้เสร็จสมบูรณ์ในกรณีที่ฉันต้องการค้นหาส่วนขยายในชื่อไฟล์เพื่อตรวจสอบฉันต้องค้นหานามสกุล '.' ในกรณีนี้ให้ใช้ rfind:

path = 'toto.titi.tata..xls'
path.find('.')
4
path.rfind('.')
15

ในกรณีของฉันฉันใช้สิ่งต่อไปนี้ซึ่งใช้งานได้กับทุกชื่อไฟล์:

filename_without_extension = complete_name[:complete_name.rfind('.')]

สิ่งนี้มีประโยชน์สำหรับการค้นหาขอบเขตของสตริง left = q.find("{"); right = q.rfind("}")ยกตัวอย่างเช่นการหาพจนานุกรมอาจจะ:
ximiki

15

จะเกิดอะไรขึ้นเมื่อสตริงมีอักขระซ้ำกัน จากประสบการณ์ของฉันกับindex()ฉันเห็นว่าสำหรับซ้ำคุณกลับดัชนีเดียวกัน

ตัวอย่างเช่น:

s = 'abccde'
for c in s:
    print('%s, %d' % (c, s.index(c)))

จะกลับมา:

a, 0
b, 1
c, 2
c, 2
d, 4

ในกรณีนี้คุณสามารถทำสิ่งนั้นได้:

for i, character in enumerate(my_string):
   # i is the position of the character in the string

enumerateดีกว่าสำหรับสิ่งนั้น
o11c

10
string.find(character)  
string.index(character)  

บางทีคุณอาจต้องการดูเอกสารประกอบเพื่อค้นหาความแตกต่างระหว่างสองสิ่งนี้


จากเอกสารที่เชื่อมโยง: s.search () จะเพิ่ม ValueError เมื่อไม่พบสตริงย่อย s.find () ส่งคืน -1 หากไม่พบสตริงย่อย
Praxiteles

7

อักขระอาจปรากฏหลายครั้งในสตริง ตัวอย่างเช่นในสตริงsentenceตำแหน่งของeคือ1, 4, 7(เนื่องจากการทำดัชนีมักเริ่มจากศูนย์) แต่สิ่งที่ฉันพบคือทั้งฟังก์ชั่นfind()และindex()ส่งกลับตำแหน่งแรกของตัวละคร ดังนั้นสิ่งนี้สามารถแก้ไขได้โดยทำสิ่งนี้:

def charposition(string, char):
    pos = [] #list to store positions for each 'char' in 'string'
    for n in range(len(string)):
        if string[n] == char:
            pos.append(n)
    return pos

s = "sentence"
print(charposition(s, 'e')) 

#Output: [1, 4, 7]

1

more_itertools.locate เป็นเครื่องมือของบุคคลที่สามที่ค้นหารายการทั้งหมดที่ตรงตามเงื่อนไข

ที่นี่เราได้พบกับทุก"i"สถานที่ดัชนีของตัวอักษร

import more_itertools as mit


s = "supercalifragilisticexpialidocious"
list(mit.locate(s, lambda x: x == "i"))
# [8, 13, 15, 18, 23, 26, 30]

0

วิธีการแก้ปัญหาด้วย numpy สำหรับการเข้าถึงดัชนีทั้งหมดอย่างรวดเร็ว:

string_array = np.array(list(my_string))
char_indexes = np.where(string_array == 'C')

4
กรุณาอย่าใช้วิธีนี้ ไม่มีเหตุผลที่ทำให้ numpy เข้าสู่การดำเนินการทำดัชนีสตริงอย่างง่าย
Mike Holler
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.