点击上方“程序员大咖”,选择“置顶公众号”

关键时刻,第一时间送达!

每个人一生中都会遇到一件事情,在事情出现之前不会关心,但是事情一旦来临就发现它极其重要,并且需要在很短的时间内做出重大决定,那就是给自己的新生宝宝起个名字。

因为要在孩子出生后两周内起个名字(需要办理出生证明了),估计很多人都像我一样,刚开始是很慌乱的,虽然感觉汉字非常的多随便找个字做名字都行,后来才发现真不是随便的事情,怎么想都发现不合适,于是到处翻词典、网上搜、翻唐诗宋词、诗经、甚至武侠小说,然而想了很久得到的名字,往往却受到家属的意见和反对,比如不顺口、和亲戚重名重音等问题,这样就陷入了重复寻找和否定的循环,越来越混乱。

于是我们再次回到网上各种搜索,找到很多网上给出的"男宝宝好听的名字大全"之类的文章,这些文章一下子给出几百上千个名字,看的眼花缭乱没法使用。而有不少的测名字的网站或者 APP ,输入名字能给出八字或者五格的评分,这样的功能感觉还挺好的能给个参考,然而要么我们需要一个个名字的输入进行测试、要么这些网站或者 APP 自身的名字很少、要么不能满足我们的需求比如限定字、要么就开始收费,到最后也找不到一个好用的。

于是我想做这么一个程序:

  1. 主要的功能,是给出批量名字提供参考,这些名字是结合宝宝的生辰八字算出来的;

  2. 自己可以扩充名字库,比如网上发现了一批诗经里的好名字,想看看怎么样,添加进去就能用;

  3. 可以限定名字的使用字,比如有的家族谱有限定,当前是"国"字辈,名字中必须有"国"字;

  4. 名字列表可以给出评分,这样倒排后就可以从高分往低分来看名字;

通过这种方式可以得到一份符合自己孩子生辰八字、自己的家谱限制、以及自己喜好的名字列表,并且该列表已经给出了分数用于参考,以此为基准我们可以挨个琢磨找出心仪的名字。当然如果有新的想法,随时可以把新的名字添加到词库里面,进行重新计算。

程序的代码结构

代码介绍:

  • /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 输出数据目录

  • /chinese-name-score/main/outputs/names_girls_source_wxy.txt 输出的示例文件

  • /chinese-name-score/main/scripts 一些对词典文件做预处理的脚本

  • /chinese-name-score/main/scripts/unique_file_lines.py 设定词典文件,对词典中的名字去重和去空白行

  • /chinese-name-score/main/sys_config.py 程序的系统配置,包含爬取得目标URL、词典文件路径

  • /chinese-name-score/main/user_config.py 程序的用户配置,包括宝宝的年月日时分性别等设定

  • /chinese-name-score/main/get_name_score.py 程序的运行入口

使用代码的方法:

  1. 如果没有限定字,就找到词典文件 names_boys_double.txt 和 names_grils_double.txt ,可以在这里添加自己找到的一些名字列表,按行分割添加在最后即可;

  2. 如果有限定字,就找到词典文件 names_boys_single.txt 和 names_girls_single.txt ,在这里添加自己预先中意的单个字列表,按行分割添加在最后即可;

  3. 打开 user_config.py ,进行配置,配置项见下一节;

  4. 运行脚本 get_name_score.py

  5. 在 outputs 目录中,查看自己的产出文件,可以复制到 Excel ,进行排序等操作;

程序的配置入口

程序的配置如下:

  1. # coding:GB18030

  2. """

  3. 在这里写好配置

  4. """

  5. setting = {}

  6. # 限定字,如果配置了该值,则会取用单字字典,否则取用多字字典

  7. setting["limit_world"] = "国"

  8. # 姓

  9. setting["name_prefix"] = "李"

  10. # 性别,取值为 男 或者 女

  11. setting["sex"] = "男"

  12. # 省份

  13. setting["area_province"] = "北京"

  14. # 城市

  15. setting["area_region"] = "海淀"

  16. # 出生的公历年份

  17. setting['year'] = "2017"

  18. # 出生的公历月份

  19. setting['month'] = "1"

  20. # 出生的公历日子

  21. setting['day'] = "11"

  22. # 出生的公历小时

  23. setting['hour'] = "11"

  24. # 出生的公历分钟

  25. setting['minute'] = "11"

  26. # 结果产出文件名称

  27. setting['output_fname'] = "names_girls_source_xxx.txt"

根据配置项 setting["limit_world"] ,系统自动来决定选用单字词典还是多字词典:

  • 如果设置了该项,比如等于"国",那么程序会组合所有的单字为名字用于计算,比如国浩和浩国两个名字都会计算;

  • 如果不设置该项,保持空字符串,则程序只会读取  * _double.txt 的双字词典

程序的原理

这是一个简单的爬虫。大家可以打开http://life.httpcn.com/xingming.asp网站查看,这是一个POST表单,填写需要的参数,点提交,就会打开一个结果页面,结果页面的最下方包含了八字分数和五格分数。

如果想得到分数,就需要做两件事情,一是爬虫自动提交表单,获取结果页面;二是从结果页面提取分数;

对于第一件事情,很简单,urllib2即可实现(代码在/chinese-name-score/main/get_name_score.py):

  1. post_data = urllib.urlencode(params)

  2. req = urllib2.urlopen(sys_config.REQUEST_URL, post_data)

  3. content = req.read()

这里的params是个参数dict,使用这种方式,就进行了POST带数据的提交,然后从content得到了结果数据。

params的参数设定如下:

  1. params = {}

  2. # 日期类型,0表示公历,1表示农历

  3. params['data_type'] = "0"

  4. params['year'] = "%s" % str(user_config.setting["year"])

  5. params['month'] = "%s" % str(user_config.setting["month"])

  6. params['day'] = "%s" % str(user_config.setting["day"])

  7. params['hour'] = "%s" % str(user_config.setting["hour"])

  8. params['minute'] = "%s" % str(user_config.setting["minute"])

  9. params['pid'] = "%s" % str(user_config.setting["area_province"])

  10. params['cid'] = "%s" % str(user_config.setting["area_region"])

  11. # 喜用五行,0表示自动分析,1表示自定喜用神

  12. params['wxxy'] = "0"

  13. params['xing'] = "%s" % (user_config.setting["name_prefix"])

  14. params['ming'] = name_postfix

  15. # 表示女,1表示男

  16. if user_config.setting["sex"] == "男":

  17.    params['sex'] = "1"

  18. else:

  19.    params['sex'] = "0"

  20. params['act'] = "submit"

  21. params['isbz'] = "1"

第二件事情,就是从网页中提取需要的分数,我们可以使用 BeautifulSoup 4来实现,其语法也很简单:

  1. soup = BeautifulSoup(content, 'html.parser', from_encoding="GB18030")

  2. full_name = get_full_name(name_postfix)

  3. # print soup.find(string=re.compile(u"姓名五格评分"))

  4. for node in soup.find_all("div", class_="chaxun_b"):

  5.    node_cont = node.get_text()

  6.    if u'姓名五格评分' in node_cont:

  7.        name_wuge = node.find(string=re.compile(u"姓名五格评分"))

  8.        result_data['wuge_score'] = name_wuge.next_sibling.b.get_text()

  9.    if u'姓名八字评分' in node_cont:

  10.        name_wuge = node.find(string=re.compile(u"姓名八字评分"))

  11.        result_data['bazi_score'] = name_wuge.next_sibling.b.get_text()

通过该方法,就能对 HTML 解析,提取八字和五格的分数。

运行结果事例

  1. 1/1287 李国锦  姓名八字评分=61.5 姓名五格评分=78.6 总分=140.1

  2. 2/1287 李国铁  姓名八字评分=61 姓名五格评分=89.7 总分=150.7

  3. 3/1287 李国晶  姓名八字评分=21 姓名五格评分=81.6 总分=102.6

  4. 4/1287 李鸣国  姓名八字评分=21 姓名五格评分=90.3 总分=111.3

  5. 5/1287 李柔国  姓名八字评分=64 姓名五格评分=78.3 总分=142.3

  6. 6/1287 李国经  姓名八字评分=21 姓名五格评分=89.8 总分=110.8

  7. 7/1287 李国蒂  姓名八字评分=22 姓名五格评分=87.2 总分=109.2

  8. 8/1287 李国登  姓名八字评分=21 姓名五格评分=81.6 总分=102.6

  9. 9/1287 李略国  姓名八字评分=21 姓名五格评分=83.7 总分=104.7

  10. 10/1287 李国添 姓名八字评分=21 姓名五格评分=81.6 总分=102.6

  11. 11/1287 李国天 姓名八字评分=22 姓名五格评分=83.7 总分=105.7

  12. 12/1287 李国田 姓名八字评分=22 姓名五格评分=93.7 总分=115.7

有了这些分数,我们就可以进行排序,是一个很实用的参考资料。

友情提示

  1. 分数跟很多因素有关,比如出生时刻、已经限定的字、限定字的笔画等因素,这些条件决定了有些名字不会分数高,不要受此影响,找出相对分数高的就可以了;

  2. 目前程序只能抓取一个网站的内容,地址是http://life.httpcn.com/xingming.asp

  3. 本列表仅供参考,看过一些文章,历史上很多名人伟人,姓名八字评分都非常低但是都建功立业,名字确实会有些影响但有时候朗朗上口就是最好的;

  4. 从本列表中选取名字之后,可以在百度、人人网等地方查查,以防有些负面的人重名、或者起这个名字的人太多了烂大街;

  5. 八字分数是中国传承,五格分数是日本人近代发明的,有时候也可以试试西方的星座起名法,并且奇怪的是八字和五个分数不同网站打分相差很大,更说明了这东西只供参考;

本文的代码已上传到github:https://github.com/peiss/chinese-name-score

  • 作者:crazyant

  • 原文链接:https://github.com/peiss/chinese-name-score

  • 程序员大咖整理发布,转载请联系作者获得授权

【点击成为Java大神】

怎样用Python给宝宝取个好名字?相关推荐

  1. python在姓名的左右_怎样用Python给宝宝取个好名字?

    通过这种方式可以得到一份符合自己孩子生辰八字.自己的家谱限制.以及自己喜好的名字列表,并且该列表已经给出了分数用于参考,以此为基准我们可以挨个琢磨找出心仪的名字.当然如果有新的想法,随时可以把新的名字 ...

  2. Python | 宝爸宝妈不用愁,怎样给宝宝取个好名字?

    作者 | crazyant 原文 | https://github.com/peiss/chinese-name-score 访问flyai.club,创建你的人工智能项目. 每个人一生中都会遇到一件 ...

  3. 人生苦短,我如何变懒,怎么用Python给宝宝起个好名字

    我的设想: 主要的功能,是给出批量名字提供参考,这些名字是结合宝宝的生辰八字算出来的: 自己可以扩充名字库,比如网上发现了一批诗经里的好名字,想看看怎么样,添加进去就能用: 可以限定名字的使用字,比如 ...

  4. python实战| 爬取虎牙高质量小姐姐私房照!

    今天给大家介绍python如何爬取虎牙小姐姐并制作心形照片墙, 有兴趣的小伙伴们一起来看看吧! 点击进去,这颜值..... i了i了 需求分析 我们的目标有5个,分别是小姐姐的 房间名称.封面照片.昵 ...

  5. python实战|爬取1000位小姐姐私房照制作照片墙,刷新你三观的颜值!

    今天给大家介绍python如何爬取虎牙小姐姐并制作心形照片墙, 有兴趣的小伙伴们一起来看看吧! 点击进去 卧槽,这颜值..... i了i了 需求分析 我们的目标有5个,分别是小姐姐的 房间名称.封面照 ...

  6. Python 多线程抓取网页 牛人 use raw socket implement http request great

    Python 多线程抓取网页 - 糖拌咸鱼 - 博客园 Python 多线程抓取网页 最近,一直在做网络爬虫相关的东西. 看了一下开源C++写的larbin爬虫,仔细阅读了里面的设计思想和一些关键技术 ...

  7. 取文字_有内涵的男孩名字:用三字经为宝宝取一个独特稀少有内涵的好名

    现在很多父母为宝宝取名字,担心重名率高.其实想为宝宝取一个独特稀少有内涵的好名字并不难.好的名字需要有情感.有文学底蕴的衬托.用<三字经>为宝宝取名,就是一个另辟蹊径的取名方法.<三 ...

  8. python requests 爬取数据

    python requests 爬取数据 import requests from lxml import etree import time import pymysql import json h ...

  9. python爬取大众点评评论_python爬虫抓取数据 小试Python——爬虫抓取大众点评上的数据 - 电脑常识 - 服务器之家...

    python爬虫抓取数据 小试Python--爬虫抓取大众点评上的数据 发布时间:2017-04-07

最新文章

  1. エターナル キングダム ~滅びの魔女と伝説の剣~验证方法
  2. 前端:JS中JSON对象和String转换
  3. 第十五届智能车竞赛东北赛区普通四轮组冠军车-哈尔滨工业大学-紫丁香
  4. SIFT定位算法关键步骤的说明
  5. placeholder的兼容处理(jQuery下)
  6. QT-Creator+SDK+编译器+自定义配置
  7. 【不体系】布谷鸟过滤器
  8. 【面向对象】第三单元总结——JML
  9. 微软 Azure App Service 漏洞 NotLegit已存在4年,客户源代码被暴露
  10. 金融危机下如何获得工作和跳槽机会-网络系统工程师的最终归宿(二)
  11. linux/ubuntu查看内核版本命令
  12. http://jingyan.baidu.com/article/fcb5aff78e6a48edab4a7146.html
  13. ZwQuerySystemInformation 枚举驱动模块
  14. 实际测试中,经常发现摄像头断线几分钟
  15. mysql 共享_Mysql局域网共享
  16. COOC软件一款用于文献计量和知识图谱绘制的新软件
  17. 停不下的脚步:IT高管人士的工作实录
  18. 超详细Klipper 上位机与下位机配置
  19. 关于2020年测绘资质新旧变化一览表
  20. 汉寿计算机培训初中升高中,中考再迎“新政策”?初中生或将直升高中,家长们终于等到了!...

热门文章

  1. Windows Server 服务器 System 占用80端口的解决办法
  2. WinForm 控件实现半透明效果,并可层叠显示
  3. 不懂Hybird开发,感觉错过一个亿~
  4. 公众号h5页面高度撑满滚动底部有白边(解决方案)
  5. matlab编程是用c语言吗,matlab调用c语言编程.doc
  6. tcl脚本使用实例 - 列表,循环,变量拼接, 文件自动写入
  7. 【网站监控】如何监控自己的网站(接口)
  8. 防范局域网内的服务器被入侵(转)
  9. HSETNX KEY_NAME(模块名) FIELD(工会标识) VALUE(值) 用法
  10. 仙侣寻缘java_Q版回合网游《问情OL》仙侣寻缘