python成语填空_python一步一步解析成语

做NLPproject时需要一个成语库,我需要的是纯成语,网上找的都是有详细解释的。于是自己写了一个爬成语的python程序。

1、首先找到一个在线成语网站

我选的网站是http://chengyu.itlearner.com/,选择它的原因是它把不同开头字母的成语分开,不同的字母和页所在的URL不同,是静态网页,比如A开头的第一页的链接是:http://chengyu.itlearner.com/list/A_1.html,所以我只要遍历各个字母开头的每页就可以了。

2、查看网页结构,定义正则式

看一下要抓的成语的标签有什么特点,查看源码,可以发现要抓的成语都在标签中,如:安如磐石,成语事实上就是一个瞄文本,不同成语指向的链接不同,其实也就"/cy0/93.html"中的数字不同,所以正则式里匹配两次数字就行了,定义正则式 reg =   "(.*?)"。

3、上代码吧

#anthor jiqunpeng#time 20121124

importurllibimportredef getHtml(url): #从URL中读取html内容

page =urllib.urlopen(url)

html=page.read()

page.close()returnhtmldef getDictionary(html): #匹配成语

reg = "(.*?)"dicList=re.compile(reg).findall(html)returndicListdef getItemSite():#手工把每个字母开头的页面数统计下来

itemSite = {}#申明为空字典

itemSite["A"] = 3itemSite["B"] = 21itemSite["C"] = 19itemSite["D"] = 18itemSite["E"] = 2itemSite["F"] = 14itemSite["G"] = 13itemSite["H"] = 15itemSite["J"] = 23itemSite["K"] = 6itemSite["L"] = 15itemSite["M"] = 12itemSite["N"] = 5itemSite["O"] = 1itemSite["P"] = 6itemSite["Q"] = 16itemSite["R"] = 8itemSite["S"] = 26itemSite["T"] = 12itemSite["W"] = 13itemSite["X"] = 16itemSite["Y"] = 35itemSite["A"] = 21

returnitemSiteif __name__== "__main__":

dicFile= open("dic.txt","w+")#保存成语的文件

domainsite = "http://chengyu.itlearner.com/list/"itemSite=getItemSite()for key,values initemSite.items():for index in range(1,values+1):

site= key +"_"+str(index)+".html"dictionary= getDictionary(getHtml(domainsite+site))for dic indictionary:

dicFile.write(dic[2]+"@@CY\n")#标记为成语,分词时使用

print key+'字母成语抓取完毕'dicFile.close()print '全部成语抓取完毕'

把成语保存在了txt文本中,还添加了一个后缀标签。这个方法太笨了,应该可以自动寻找下一页,而不是我先确定好页面数量。以后有时间再整,最近project+考试。

最后注意,设计正则表达式时可能会出现明明认为是正确的,就是匹配不了,对空白字符要留意,比如说要解析:

你看不出第一行与第二行的空白字符是什么,可以index = html.find('avatar_name'),html[4677:4677+100]看到非空白字符

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值