ฉันจะรับตำแหน่งของตัวละครภายในสตริงในไพ ธ อนได้อย่างไร?
ฉันจะรับตำแหน่งของตัวละครภายในสตริงในไพ ธ อนได้อย่างไร?
คำตอบ:
มีสองวิธีสตริงนี้, และ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
string.find(s, sub[, start[, end]])
กลับดัชนีต่ำสุดในsที่ substring ย่อยพบดังกล่าวที่ย่อยs[start:end]
ที่มีอยู่ในเครือใน ผลตอบแทน-1
จากความล้มเหลว ค่าเริ่มต้นสำหรับการเริ่มต้นและสิ้นสุดและการตีความค่าลบเป็นเช่นเดียวกับชิ้น
และ:
string.index(s, sub[, start[, end]])
กดไลค์find()
แต่เพิ่มValueError
เมื่อไม่พบสตริงย่อย
เพียงเพื่อความสมบูรณ์ถ้าคุณต้องการค้นหาตำแหน่งทั้งหมดของตัวละครในสตริงคุณสามารถทำสิ่งต่อไปนี้:
s = 'shak#spea#e'
c = '#'
print [pos for pos, char in enumerate(s) if char == c]
ซึ่งจะกลับมา [4, 9]
print( [pos for pos, char in enumerate(s) if char == c])
foo = ( [pos for pos, char in enumerate(s) if char == c])
จะวางfooพิกัดในรูปแบบรายการ ฉันพบว่ามีประโยชน์จริง ๆ
>>> 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'
str[from:to]
ที่ไหนfrom
และto
มีดัชนี
เพื่อให้เสร็จสมบูรณ์ในกรณีที่ฉันต้องการค้นหาส่วนขยายในชื่อไฟล์เพื่อตรวจสอบฉันต้องค้นหานามสกุล '.' ในกรณีนี้ให้ใช้ 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("}")
ยกตัวอย่างเช่นการหาพจนานุกรมอาจจะ:
จะเกิดอะไรขึ้นเมื่อสตริงมีอักขระซ้ำกัน จากประสบการณ์ของฉันกับ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
ดีกว่าสำหรับสิ่งนั้น
string.find(character)
string.index(character)
บางทีคุณอาจต้องการดูเอกสารประกอบเพื่อค้นหาความแตกต่างระหว่างสองสิ่งนี้
อักขระอาจปรากฏหลายครั้งในสตริง ตัวอย่างเช่นในสตริง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]
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]
วิธีการแก้ปัญหาด้วย numpy สำหรับการเข้าถึงดัชนีทั้งหมดอย่างรวดเร็ว:
string_array = np.array(list(my_string))
char_indexes = np.where(string_array == 'C')