前言
相信每位家長都有所體會,因為要在孩子出生后兩周內起個名字(需要辦理出生證明了),估計很多人都像我一樣,剛開始是很慌亂的,雖然感覺漢字非常的多隨便找個字做名字都行,后來才發現真不是隨便的事情,怎么想都發現不合適,于是到處翻詞典、網上搜、翻唐詩宋詞、詩經、甚至武俠小說,然而想了很久得到的名字,往往卻受到家屬的意見和反對,比如不順口、和親戚重名重音等問題,這樣就陷入了重復尋找和否定的循環,越來越混亂。
于是我們再次回到網上各種搜索,找到很多網上給出的“男寶寶好聽的名字大全”之類的文章,這些文章一下子給出幾百上千個名字,看的眼花繚亂沒法使用。而有不少的測名字的網站或者APP,輸入名字能給出八字或者五格的評分,這樣的功能感覺還挺好的能給個參考,然而要么我們需要一個個名字的輸入進行測試、要么這些網站或者APP自身的名字很少、要么不能滿足我們的需求比如限定字、要么就開始收費,到最后也找不到一個好用的。
于是我想做這么一個程序:
通過這種方式可以得到一份符合自己孩子生辰八字、自己的家譜限制、以及自己喜好的名字列表,并且該列表已經給出了分數用于參考,以此為基準我們可以挨個琢磨找出心儀的名字。當然如果有新的想法,隨時可以把新的名字添加到詞庫里面,進行重新計算。
程序的代碼結構

代碼介紹:
使用代碼的方法:
程序的配置入口
程序的配置如下:
# coding:GB18030 """在這里寫好配置""" setting = {} # 限定字,如果配置了該值,則會取用單字字典,否則取用多字字典setting["limit_world"] = "國"# 姓setting["name_prefix"] = "李"# 性別,取值為 男 或者 女setting["sex"] = "男"# 省份setting["area_province"] = "北京"# 城市setting["area_region"] = "海淀"# 出生的公歷年份setting['year'] = "2017"# 出生的公歷月份setting['month'] = "1"# 出生的公歷日子setting['day'] = "11"# 出生的公歷小時setting['hour'] = "11"# 出生的公歷分鐘setting['minute'] = "11"# 結果產出文件名稱setting['output_fname'] = "names_girls_source_xxx.txt"根據配置項setting[“limit_world”] ,系統自動來決定選用單字詞典還是多字詞典:
程序的原理
這是一個簡單的爬蟲。大家可以打開http://life.httpcn.com/xingming.asp網站查看,這是一個POST表單,填寫需要的參數,點提交,就會打開一個結果頁面,結果頁面的最下方包含了八字分數和五格分數。
如果想得到分數,就需要做兩件事情,一是爬蟲自動提交表單,獲取結果頁面;二是從結果頁面提取分數;
對于第一件事情,很簡單,urllib2即可實現(代碼在/chinese-name-score/main/get_name_score.py):
post_data = urllib.urlencode(params) req = urllib2.urlopen(sys_config.REQUEST_URL, post_data) content = req.read()
這里的params是個參數dict,使用這種方式,就進行了POST帶數據的提交,然后從content得到了結果數據。
params的參數設定如下:
params = {} # 日期類型,0表示公歷,1表示農歷 params['data_type'] = "0" params['year'] = "%s" % str(user_config.setting["year"]) params['month'] = "%s" % str(user_config.setting["month"]) params['day'] = "%s" % str(user_config.setting["day"]) params['hour'] = "%s" % str(user_config.setting["hour"]) params['minute'] = "%s" % str(user_config.setting["minute"]) params['pid'] = "%s" % str(user_config.setting["area_province"]) params['cid'] = "%s" % str(user_config.setting["area_region"]) # 喜用五行,0表示自動分析,1表示自定喜用神 params['wxxy'] = "0" params['xing'] = "%s" % (user_config.setting["name_prefix"]) params['ming'] = name_postfix # 表示女,1表示男 if user_config.setting["sex"] == "男": params['sex'] = "1" else: params['sex'] = "0" params['act'] = "submit" params['isbz'] = "1"第二件事情,就是從網頁中提取需要的分數,我們可以使用BeautifulSoup4來實現,其語法也很簡單:
soup = BeautifulSoup(content, 'html.parser', from_encoding="GB18030") full_name = get_full_name(name_postfix) # print soup.find(string=re.compile(u"姓名五格評分")) for node in soup.find_all("div", class_="chaxun_b"): node_cont = node.get_text() if u'姓名五格評分' in node_cont: name_wuge = node.find(string=re.compile(u"姓名五格評分")) result_data['wuge_score'] = name_wuge.next_sibling.b.get_text() if u'姓名八字評分' in node_cont: name_wuge = node.find(string=re.compile(u"姓名八字評分")) result_data['bazi_score'] = name_wuge.next_sibling.b.get_text()通過該方法,就能對HTML解析,提取八字和五格的分數。
運行結果事例
1/1287 李國錦 姓名八字評分=61.5 姓名五格評分=78.6 總分=140.12/1287 李國鐵 姓名八字評分=61 姓名五格評分=89.7 總分=150.73/1287 李國晶 姓名八字評分=21 姓名五格評分=81.6 總分=102.64/1287 李鳴國 姓名八字評分=21 姓名五格評分=90.3 總分=111.35/1287 李柔國 姓名八字評分=64 姓名五格評分=78.3 總分=142.36/1287 李國經 姓名八字評分=21 姓名五格評分=89.8 總分=110.87/1287 李國蒂 姓名八字評分=22 姓名五格評分=87.2 總分=109.28/1287 李國登 姓名八字評分=21 姓名五格評分=81.6 總分=102.69/1287 李略國 姓名八字評分=21 姓名五格評分=83.7 總分=104.710/1287 李國添 姓名八字評分=21 姓名五格評分=81.6 總分=102.611/1287 李國天 姓名八字評分=22 姓名五格評分=83.7 總分=105.712/1287 李國田 姓名八字評分=22 姓名五格評分=93.7 總分=115.7
有了這些分數,我們就可以進行排序,是一個很實用的參考資料。
友情提示
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家學習或使用python能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。
新聞熱點
疑難解答
圖片精選