看板 Python 關於我們 聯絡資訊
分享一下我後來的作法, 是用 re.sub 來把字母的部分挑出來。 然後用 Counter 整理後確認長度(len)就可以回傳 True 或 False 程式碼如下請參考: import re from collections import Counter def is_pangram(s): purified_s = re.sub(r'[^a-z]',"", s.lower()) ps = len(Counter(purified_s)) if ps == 26: return True else: return False ※ 引述《outshaker (out)》之銘言: : 我把你的資料改成 s="abc!@#$" 跑過同樣的程式碼變成 "abc@$" : 這表示!和#有被程式讀取到,但@和$應該是跳過沒有被讀取到 : 推測原因是你使用remove刪除了資料影響原本的讀取 : 一般這種loop是按照順序(或稱index)去讀資料的 : 讀到第4個字元,發現是!,移除掉該元素,清單變成"abc@#$" : 123456 : 下一次抓的是第5個字元,是#,移除該元素,清單變成"abc@$" : 12345 : 下一次抓第6個字元,這時候清單已經抓不到字元了,於是退出loop : 要檢查程式碼運作其實很簡單,加一段print(ascii_i) 就可以知道資料會怎麼變化 : 然後再加一些推理就可以猜出原因 : 最後真的不建議在迴圈裡面增加或刪除資料 : 改變清單的大小,程式會有很多不預期的結果 : 原PO推文已經有建議用set或counter了,都是現成且方便的解決方案 : 這邊我也給一個做法,先把字母挑出來做成一張表,然後檢查a-z是否都有出現在裡面 : def test(s): : t = [] : for c in s: : if 'a' <= c <= 'z' or 'A' <= c <= 'Z': : t.append(c.lower()) # 把字母加進清單 : a = "abcdefghijklmnopqrstuvwxyz" : return all([x in t for x in a]) : all() 是用來檢查所有條件都成立的 : [x in t for x in a] 是縮寫,等同於以下內容: : list_ = [] : for x in a: # x 代表a-z的字母 : list_.append(x in t) # 檢查字母是否在清單內 : 然後把字母加入清單的部分可以用 filter() 的寫法,有興趣你再找相關資料 : 以上 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 60.249.220.81 (臺灣) ※ 文章網址: https://www.ptt.cc/bbs/Python/M.1582697531.A.B46.html
outshaker: return ps == 26 這會更簡潔有力歐 02/26 22:18
好!謝謝大大!(筆記) ※ 編輯: yvmi (122.116.23.224 臺灣), 03/09/2020 15:00:43