[英]Find strings in a list that between specific ascii values - Python
我試圖在下限和上限之間的列表中找到某些字符串(這些是用戶輸入值)。 例如,假設我有一個列表,states = ['OH', 'NJ', 'NY', 'SD', 'NH', 'WI']。 用戶輸入 lowerbound = 'NJ' 和 upperbound = 'SD'。 我想要代碼為 output ['OH', 'NJ', 'NY', 'SD']。
我認為我可以做的是將每個字符串分成它自己的單獨字符。
因此,對於用戶輸入,我寫了這個以便添加輸入的 ascii 值。 在這種情況下,每個字符都是從輸入中添加的。
a = ord(lowerbound[0].lower()) + ord(lowerbound[1].lower())
b = ord(upperbound[0].lower()) + ord(upperbound[1].lower())
因此,我嘗試了這個來檢索列表中用戶輸入之間的元素。 首先,它將列表中的所有元素轉換為它們添加的 ascii 值。 但它並沒有給我我想要的 output。
s_lst = []
lst = []
for s in states:
x = ord(s[0].lower()) + ord(s[1].lower())
lst.append(x)
for i in lst:
if (b >= i >= a):
s_lst.append(i)
print(s_lst)
使用列表理解來過濾列表:
states = ['OH', 'NJ', 'NY', 'SD', 'NH', 'WI']
lowerbound = 'NJ'
upperbound = 'SD'
>>> [state for state in states if lowerbound<=state<=upperbound]
['OH', 'NJ', 'NY', 'SD']
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.