作者yvmi (鞭策自己社社长)
看板Python
标题Re: [问题] 新手for+判断式问题
时间Wed Feb 26 14:12:09 2020
分享一下我後来的作法,
是用 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://webptt.com/cn.aspx?n=bbs/Python/M.1582697531.A.B46.html
1F:→ outshaker: return ps == 26 这会更简洁有力欧 02/26 22:18
好!谢谢大大!(笔记)
※ 编辑: yvmi (122.116.23.224 台湾), 03/09/2020 15:00:43