欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用Python爬蟲給孩子起個(gè)好名字

 更新時(shí)間:2017年02月14日 10:26:38   作者:Crazyant  
每個(gè)人一生中都會(huì)遇到一件事情,在事情出現(xiàn)之前不會(huì)關(guān)心,但是事情一旦來(lái)臨就發(fā)現(xiàn)它極其重要,并且需要在很短的時(shí)間內(nèi)做出重大決定,那就是給自己的新生寶寶起個(gè)名字。下面這篇文章主要介紹了如何利用Python爬蟲給孩子起個(gè)好名字,需要的朋友可以參考下。

前言

相信每位家長(zhǎng)都有所體會(huì),因?yàn)橐诤⒆映錾髢芍軆?nèi)起個(gè)名字(需要辦理出生證明了),估計(jì)很多人都像我一樣,剛開始是很慌亂的,雖然感覺(jué)漢字非常的多隨便找個(gè)字做名字都行,后來(lái)才發(fā)現(xiàn)真不是隨便的事情,怎么想都發(fā)現(xiàn)不合適,于是到處翻詞典、網(wǎng)上搜、翻唐詩(shī)宋詞、詩(shī)經(jīng)、甚至武俠小說(shuō),然而想了很久得到的名字,往往卻受到家屬的意見(jiàn)和反對(duì),比如不順口、和親戚重名重音等問(wèn)題,這樣就陷入了重復(fù)尋找和否定的循環(huán),越來(lái)越混亂。

于是我們?cè)俅位氐骄W(wǎng)上各種搜索,找到很多網(wǎng)上給出的“男寶寶好聽(tīng)的名字大全”之類的文章,這些文章一下子給出幾百上千個(gè)名字,看的眼花繚亂沒(méi)法使用。而有不少的測(cè)名字的網(wǎng)站或者APP,輸入名字能給出八字或者五格的評(píng)分,這樣的功能感覺(jué)還挺好的能給個(gè)參考,然而要么我們需要一個(gè)個(gè)名字的輸入進(jìn)行測(cè)試、要么這些網(wǎng)站或者APP自身的名字很少、要么不能滿足我們的需求比如限定字、要么就開始收費(fèi),到最后也找不到一個(gè)好用的。

于是我想做這么一個(gè)程序:

  1. 主要的功能,是給出批量名字提供參考,這些名字是結(jié)合寶寶的生辰八字算出來(lái)的;
  2. 自己可以擴(kuò)充名字庫(kù),比如網(wǎng)上發(fā)現(xiàn)了一批詩(shī)經(jīng)里的好名字,想看看怎么樣,添加進(jìn)去就能用;
  3. 可以限定名字的使用字,比如有的家族譜有限定,當(dāng)前是“國(guó)”字輩,名字中必須有“國(guó)”字;
  4. 名字列表可以給出評(píng)分,這樣倒排后就可以從高分往低分來(lái)看名字;

通過(guò)這種方式可以得到一份符合自己孩子生辰八字、自己的家譜限制、以及自己喜好的名字列表,并且該列表已經(jīng)給出了分?jǐn)?shù)用于參考,以此為基準(zhǔn)我們可以挨個(gè)琢磨找出心儀的名字。當(dāng)然如果有新的想法,隨時(shí)可以把新的名字添加到詞庫(kù)里面,進(jìn)行重新計(jì)算。

程序的代碼結(jié)構(gòu)

代碼介紹:

  • /chinese-name-score 代碼根目錄
  • /chinese-name-score/main 代碼目錄
  • /chinese-name-score/main/dicts 詞典文件目錄
  • /chinese-name-score/main/dicts/names_boys_double.txt 詞典文件,男孩的雙字名字
  • /chinese-name-score/main/dicts/names_boys_single.txt 詞典文件,男孩的單字名字
  • /chinese-name-score/main/dicts/names_girls_single.txt 詞典文件,女孩的雙字名字
  • /chinese-name-score/main/dicts/names_grils_double.txt 詞典文件,女孩的單字名字
  • /chinese-name-score/main/outputs 輸出數(shù)據(jù)目錄
  • /chinese-name-score/main/outputs/names_girls_source_wxy.txt 輸出的示例文件
  • /chinese-name-score/main/scripts 一些對(duì)詞典文件做預(yù)處理的腳本
  • /chinese-name-score/main/scripts/unique_file_lines.py 設(shè)定詞典文件,對(duì)詞典中的名字去重和去空白行
  • /chinese-name-score/main/sys_config.py 程序的系統(tǒng)配置,包含爬取得目標(biāo)URL、詞典文件路徑
  • /chinese-name-score/main/user_config.py 程序的用戶配置,包括寶寶的年月日時(shí)分性別等設(shè)定
  • /chinese-name-score/main/get_name_score.py 程序的運(yùn)行入口

使用代碼的方法:

  1. 如果沒(méi)有限定字,就找到詞典文件names_boys_double.txt和names_grils_double.txt,可以在這里添加自己找到的一些名字列表,按行分割添加在最后即可;
  2. 如果有限定字,就找到詞典文件names_boys_single.txt和names_girls_single.txt,在這里添加自己預(yù)先中意的單個(gè)字列表,按行分割添加在最后即可;
  3. 打開user_config.py,進(jìn)行配置,配置項(xiàng)見(jiàn)下一節(jié);
  4. 運(yùn)行腳本get_name_score.py
  5. 在outputs目錄中,查看自己的產(chǎn)出文件,可以復(fù)制到Excel,進(jìn)行排序等操作;

程序的配置入口

程序的配置如下:

# coding:GB18030
 
"""
在這里寫好配置
"""
 
setting = {}
 
# 限定字,如果配置了該值,則會(huì)取用單字字典,否則取用多字字典
setting["limit_world"] = "國(guó)"
# 姓
setting["name_prefix"] = "李"
# 性別,取值為 男 或者 女
setting["sex"] = "男"
# 省份
setting["area_province"] = "北京"
# 城市
setting["area_region"] = "海淀"
# 出生的公歷年份
setting['year'] = "2017"
# 出生的公歷月份
setting['month'] = "1"
# 出生的公歷日子
setting['day'] = "11"
# 出生的公歷小時(shí)
setting['hour'] = "11"
# 出生的公歷分鐘
setting['minute'] = "11"
# 結(jié)果產(chǎn)出文件名稱
setting['output_fname'] = "names_girls_source_xxx.txt"

根據(jù)配置項(xiàng)setting[“l(fā)imit_world”] ,系統(tǒng)自動(dòng)來(lái)決定選用單字詞典還是多字詞典:

  1. 如果設(shè)置了該項(xiàng),比如等于“國(guó)”,那么程序會(huì)組合所有的單字為名字用于計(jì)算,比如國(guó)浩和浩國(guó)兩個(gè)名字都會(huì)計(jì)算;
  2. 如果不設(shè)置該項(xiàng),保持空字符串,則程序只會(huì)讀取*_double.txt的雙字詞典

程序的原理

這是一個(gè)簡(jiǎn)單的爬蟲。大家可以打開http://life.httpcn.com/xingming.asp網(wǎng)站查看,這是一個(gè)POST表單,填寫需要的參數(shù),點(diǎn)提交,就會(huì)打開一個(gè)結(jié)果頁(yè)面,結(jié)果頁(yè)面的最下方包含了八字分?jǐn)?shù)和五格分?jǐn)?shù)。

如果想得到分?jǐn)?shù),就需要做兩件事情,一是爬蟲自動(dòng)提交表單,獲取結(jié)果頁(yè)面;二是從結(jié)果頁(yè)面提取分?jǐn)?shù);

對(duì)于第一件事情,很簡(jiǎn)單,urllib2即可實(shí)現(xiàn)(代碼在/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是個(gè)參數(shù)dict,使用這種方式,就進(jìn)行了POST帶數(shù)據(jù)的提交,然后從content得到了結(jié)果數(shù)據(jù)。

params的參數(shù)設(shè)定如下:

 params = {}
 
 # 日期類型,0表示公歷,1表示農(nóng)歷
 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表示自動(dòng)分析,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"

第二件事情,就是從網(wǎng)頁(yè)中提取需要的分?jǐn)?shù),我們可以使用BeautifulSoup4來(lái)實(shí)現(xiàn),其語(yǔ)法也很簡(jiǎn)單:

 soup = BeautifulSoup(content, 'html.parser', from_encoding="GB18030")
 full_name = get_full_name(name_postfix)
 
 # print soup.find(string=re.compile(u"姓名五格評(píng)分"))
 for node in soup.find_all("div", class_="chaxun_b"):
  node_cont = node.get_text()
  if u'姓名五格評(píng)分' in node_cont:
   name_wuge = node.find(string=re.compile(u"姓名五格評(píng)分"))
   result_data['wuge_score'] = name_wuge.next_sibling.b.get_text()
  
  if u'姓名八字評(píng)分' in node_cont:
   name_wuge = node.find(string=re.compile(u"姓名八字評(píng)分"))
   result_data['bazi_score'] = name_wuge.next_sibling.b.get_text()

通過(guò)該方法,就能對(duì)HTML解析,提取八字和五格的分?jǐn)?shù)。

運(yùn)行結(jié)果事例

1/1287 李國(guó)錦 姓名八字評(píng)分=61.5 姓名五格評(píng)分=78.6 總分=140.1
2/1287 李國(guó)鐵 姓名八字評(píng)分=61 姓名五格評(píng)分=89.7 總分=150.7
3/1287 李國(guó)晶 姓名八字評(píng)分=21 姓名五格評(píng)分=81.6 總分=102.6
4/1287 李鳴國(guó) 姓名八字評(píng)分=21 姓名五格評(píng)分=90.3 總分=111.3
5/1287 李柔國(guó) 姓名八字評(píng)分=64 姓名五格評(píng)分=78.3 總分=142.3
6/1287 李國(guó)經(jīng) 姓名八字評(píng)分=21 姓名五格評(píng)分=89.8 總分=110.8
7/1287 李國(guó)蒂 姓名八字評(píng)分=22 姓名五格評(píng)分=87.2 總分=109.2
8/1287 李國(guó)登 姓名八字評(píng)分=21 姓名五格評(píng)分=81.6 總分=102.6
9/1287 李略國(guó) 姓名八字評(píng)分=21 姓名五格評(píng)分=83.7 總分=104.7
10/1287 李國(guó)添 姓名八字評(píng)分=21 姓名五格評(píng)分=81.6 總分=102.6
11/1287 李國(guó)天 姓名八字評(píng)分=22 姓名五格評(píng)分=83.7 總分=105.7
12/1287 李國(guó)田 姓名八字評(píng)分=22 姓名五格評(píng)分=93.7 總分=115.7

有了這些分?jǐn)?shù),我們就可以進(jìn)行排序,是一個(gè)很實(shí)用的參考資料。

友情提示

  1. 分?jǐn)?shù)跟很多因素有關(guān),比如出生時(shí)刻、已經(jīng)限定的字、限定字的筆畫等因素,這些條件決定了有些名字不會(huì)分?jǐn)?shù)高,不要受此影響,找出相對(duì)分?jǐn)?shù)高的就可以了;
  2. 目前程序只能抓取一個(gè)網(wǎng)站的內(nèi)容,地址是http://life.httpcn.com/xingming.asp
  3. 本列表僅供參考,看過(guò)一些文章,歷史上很多名人偉人,姓名八字評(píng)分都非常低但是都建功立業(yè),名字確實(shí)會(huì)有些影響但有時(shí)候朗朗上口就是最好的;
  4. 從本列表中選取名字之后,可以在百度、人人網(wǎng)等地方查查,以防有些負(fù)面的人重名、或者起這個(gè)名字的人太多了爛大街;
  5. 八字分?jǐn)?shù)是中國(guó)傳承,五格分?jǐn)?shù)是日本人近代發(fā)明的,有時(shí)候也可以試試西方的星座起名法,并且奇怪的是八字和五個(gè)分?jǐn)?shù)不同網(wǎng)站打分相差很大,更說(shuō)明了這東西只供參考;

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家學(xué)習(xí)或使用python能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • Python的speech_recognition庫(kù)如何將聲音轉(zhuǎn)為文字

    Python的speech_recognition庫(kù)如何將聲音轉(zhuǎn)為文字

    這篇文章主要介紹了通過(guò)Python的speech_recognition庫(kù)將聲音轉(zhuǎn)為文字,將聲音轉(zhuǎn)為文字,除了speech_recognition庫(kù),還要依賴pyaudio庫(kù),而且mac用戶需要安裝PortAudio,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • CentOS7.3編譯安裝Python3.6.2的方法

    CentOS7.3編譯安裝Python3.6.2的方法

    本篇文章主要介紹了CentOS7.3編譯安裝Python3.6.2的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01
  • Python函數(shù)式編程中itertools模塊詳解

    Python函數(shù)式編程中itertools模塊詳解

    這篇文章主要介紹了在Python中使用itertools模塊中的組合函數(shù)的教程,來(lái)自IBM官方技術(shù)文檔,需要的朋友可以參考下,希望能夠給你帶來(lái)幫助
    2021-09-09
  • Python PIL實(shí)現(xiàn)GIF壓縮工具

    Python PIL實(shí)現(xiàn)GIF壓縮工具

    本文將結(jié)合wxPython的GUI框架和PIL(Python Imaging Library)的圖像處理能力編寫一個(gè)GIF壓縮工具,并提供了兩種壓縮方式,感興趣的小伙伴可以了解下
    2024-10-10
  • 在jupyter notebook 添加 conda 環(huán)境的操作詳解

    在jupyter notebook 添加 conda 環(huán)境的操作詳解

    這篇文章主要介紹了在jupyter notebook 添加 conda 環(huán)境的操作詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-04-04
  • Python的列表推導(dǎo)式實(shí)例詳細(xì)解析

    Python的列表推導(dǎo)式實(shí)例詳細(xì)解析

    這篇文章主要介紹了Python的列表推導(dǎo)式實(shí)例詳細(xì)解析,列表推導(dǎo)式是Python構(gòu)建列表list的一種快捷方式,可以使用簡(jiǎn)潔的代碼就創(chuàng)建出一個(gè)列表,需要的朋友可以參考下
    2023-07-07
  • Python使用cookielib模塊操作cookie的實(shí)例教程

    Python使用cookielib模塊操作cookie的實(shí)例教程

    cookielib模塊經(jīng)常被用來(lái)和urllib等模塊配合來(lái)制作爬蟲或者第三方SNS客戶端等程序,比如這里我們就將舉一個(gè)使用cookie來(lái)發(fā)送登錄信息登錄人人網(wǎng)的例子,well,一起來(lái)看一下Python使用cookielib模塊操作cookie的實(shí)例教程
    2016-07-07
  • python中文分詞+詞頻統(tǒng)計(jì)的實(shí)現(xiàn)步驟

    python中文分詞+詞頻統(tǒng)計(jì)的實(shí)現(xiàn)步驟

    詞頻統(tǒng)計(jì)就是輸入一段句子或者一篇文章,然后統(tǒng)計(jì)句子中每個(gè)單詞出現(xiàn)的次數(shù),下面這篇文章主要給大家介紹了關(guān)于python中文分詞+詞頻統(tǒng)計(jì)的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • 關(guān)于pyqtSignal的基本使用

    關(guān)于pyqtSignal的基本使用

    這篇文章主要介紹了關(guān)于pyqtSignal的基本使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Python 保存加載mat格式文件的示例代碼

    Python 保存加載mat格式文件的示例代碼

    這篇文章主要介紹了Python 保存加載mat格式文件的示例代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08

最新評(píng)論