-
Notifications
You must be signed in to change notification settings - Fork 135
/
Symbol_Structure.py
42 lines (36 loc) · 1.75 KB
/
Symbol_Structure.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# -*-coding:utf-8-*-
# 此模块用于爬取汉字结构字典
import requests
from bs4 import BeautifulSoup
import re
from tqdm import tqdm
def get_url():
file1 = open('D:/py/Word_Structure_Dict.txt', 'w', encoding='utf-8')
file1.truncate()
file1.close()
# 依次为单一结构,左右结构,上下结构,左中右结构,上中下结构,右上包围结构,左上包围结构,左下包围结构,上三包围结构,下三包围结构,左三包围结构,全包围结构,镶嵌结构,品字结构
key_word_lst = ['danyi', 'zuoyou', 'shangxia', 'zuozhongyou', 'shangzhongxia', 'youshangbaowei', 'zuoshangbaowei',
'zuoxiabaowei', 'xiasanbaowei', 'shangsanbaowei', 'zuosanbaowei', 'quanbaowei', 'xiangqian', 'pinzi']
header = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) \
Chrome/63.0.3239.132 Safari/537.36'}
for index, key_word in enumerate(key_word_lst):
file1 = open('D:/py/Word_Structure_Dict.txt', 'a', encoding='utf-8')
url = 'http://zidian.miaochaxun.com/'+key_word+'.html'
print(url)
res1 = requests.get(url, headers=header)
res1.encoding = 'utf-8'
soup1 = BeautifulSoup(res1.text, 'html.parser')
zi_list = soup1.find_all('p', class_='zi')
for s in zi_list:
[p.extract() for p in s.find_all('span')]
for s in zi_list:
for word in s.find_all('a'):
# print(word.get_text())
try:
file1.write("'{0}':'{1}',\n".format(word.get_text(), index))
except TypeError:
pass
continue
file1.close()
if __name__ == '__main__':
get_url()