[英]How to compare individual characters in two strings in Python 3
我正在嘗試比較兩個不同字符串(等等)的第一個字符,以根據這些結果形成一個新字符串。 這是我嘗試使用的,但是它將每個列表的每個元素相互比較。
def compare(a,b):
s = ""
for x in a:
for y in b:
if x == y:
s+=str(x)
else:
s+=str(y)
這似乎是一個如此簡單的問題,但我被卡住了。
使用郵編:
def compare(a, b):
for x, y in zip(a, b):
if x == y:
...
您是否正在尋找與此邏輯類似的東西? 它從每個輸入字符串中選擇按字母順序較早的字符:
def compare(a,b):
s = ""
for i in range(len(a)):
if a[i] < b[i]:
s+=str(a[i])
else:
s+=str(b[i])
return s
print compare ("seven", "eight")
輸出:
eegen
這個的單行版本是
return ''.join(a[i] if a[i] < b[i] else b[i] for i in range(len(a)))
input(x)
input(y)
cnt = 0
for char_val in x:
if b[cnt] == char_val:
print("match")
else:
print("mis-match")
這里有一個完整的功能
def compare_strings(a,b):
result = True
if len(a) != len(b): print('string lengths do not match!')
for i,(x,y) in enumerate(zip(a,b)):
if x != y:
print(f'char miss-match {x,y} in element {i}')
result = False
if result: print('strings match!')
return result
def twoStrings(s1, s2):
for i in range(len(s1)):
for j in range(len(s2)):
if s2[j] == s1[i]:
return 'YES'
return 'NO'
我們可以編寫簡單易行的方法來比較兩個字符串中的相似字母
def compare(a,b):
s = ""
t=""
for x in a:
for y in b:
if x == y:
t=x
s=s+t
print(s)
compare("xyz","axy")
這里第一個for loop
將比較字符串中的每個字母並顯示所有相似的字符。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.