文章详情页
正则表达式 - 请问用 Python 如何匹配汉语拼音?
浏览:181日期:2022-06-30 09:24:43
问题描述
比如用正则表达式匹配出 shá 这个拼音。 ps:之前说的可能不明确,我用了 “ 比如 ” 两字哈,就是待处理文本里有拼音,但是不知道具体拼音是什么,需要找出这些拼音,待处理文本会有 中文、拼音、符号(,。:之类的),所以请不要回答诸如re.search(u’shá’,text) 要正则哈,不是简单固定的字符串。。。
问题解答
回答1:import reregex = re.compile(r’b[a-z]*[āáǎàōóǒòêēéěèīíǐìūúǔùǖǘǚǜüńňǹɑɡ]+[a-z]*b’)text = 'Thǐs ís à pìnyin abóut shá'm = regex.findall(text)print(m)
匹配结果:[’ís’, ’à’, ’pìnyin’, ’abóut’, ’shá’]没有匹配第一个Thǐs,因为默认拼音都是小写,排除了大写。
回答2:你是要匹配所有合法的拼音吗?
如果是,你去找个字典的拼音索引,把里边的所有拼音全部 | 到一起就可以了。也只能这样,因为拼音不是根据正则,或者其它某种机械的规则定义出来的。你想不漏又不多就只能这样了,反正也没多少个。
回答3:>>> import re>>> d=’shá’>>> data=’This is a pinyin about shá’>>> re.search(d,data)<_sre.SRE_Match at 0x404e308>
相关文章:
1. javascript - 用表单提交两个时间段请求后台返回对应数据时出现的一些问题!2. dockerfile - [docker build image失败- npm install]3. docker内创建jenkins访问另一个容器下的服务器问题4. java中关于直接插入排序遇到的问题。5. javascript - c#如何向js传值6. node.js - nodejs和前端JavaScript 字符串处理结果不一样是什么原因?7. docker gitlab 如何git clone?8. node.js - mongoDB使用$gte的问题9. java - mybatis怎么实现在数据库中有就修改,没有就添加10. 我在centos容器里安装docker,也就是在容器里安装容器,报错了?
排行榜
