Re: [問題] 新手for+判斷式問題

作者: yvmi (鞭策自己社社長)   2020-02-26 14:12:09
分享一下我後來的作法,
是用 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="[email protected]#$" 跑過同樣的程式碼變成 "[email protected]$"
: 這表示!和#有被程式讀取到,但@和$應該是跳過沒有被讀取到
: 推測原因是你使用remove刪除了資料影響原本的讀取
: 一般這種loop是按照順序(或稱index)去讀資料的
: 讀到第4個字元,發現是!,移除掉該元素,清單變成"[email protected]#$"
: 123456
: 下一次抓的是第5個字元,是#,移除該元素,清單變成"[email protected]$"
: 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() 的寫法,有興趣你再找相關資料
: 以上
作者: outshaker (out)   2020-02-26 22:18:00
return ps == 26 這會更簡潔有力歐

Links booklink

Contact Us: admin [ a t ] ucptt.com