给新生宝宝起个名字,你真的了解吗?
源 / 疯狂的蚂蚁
每个人一生中都会遇到一件事情,在事情出现之前不会关心,但是事情一旦来临就发现它极其重要,并且需要在很短的时间内做出重大决定给新生宝宝起个名字,你真的了解吗?,那就是给自己的新生宝宝起个名字。
因为要在孩子出生后两周内起个名字(需要办理出生证明了),估计很多人都像我一样,刚开始是很慌乱的,虽然感觉汉字非常的多随便找个字做名字都行,后来才发现真不是随便的事情,怎么想都发现不合适,于是到处翻词典、网上搜、翻唐诗宋词、诗经、甚至武侠小说,然而想了很久得到的名字,往往却受到家属的意见和反对,比如不顺口、和亲戚重名重音等问题,这样就陷入了重复寻找和否定的循环,越来越混乱。
于是我们再次回到网上各种搜索,找到很多网上给出的“男宝宝好听的名字大全”之类的文章,这些文章一下子给出几百上千个名字,看的眼花缭乱没法使用。而有不少的测名字的网站或者APP,输入名字能给出八字或者五格的评分,这样的功能感觉还挺好的能给个参考,然而要么我们需要一个个名字的输入进行测试、要么这些网站或者APP自身的名字很少、要么不能满足我们的需求比如限定字、要么就开始收费,到最后也找不到一个好用的。
于是我想做这么一个程序:
主要的功能,是给出批量名字提供参考,这些名字是结合宝宝的生辰八字算出来的; 自己可以扩充名字库,比如网上发现了一批诗经里的好名字,想看看怎么样,添加进去就能用; 可以限定名字的使用字,比如有的家族谱有限定,当前是“国”字辈周易生辰八字测名字打分最准,名字中必须有“国”字; 名字列表可以给出评分,这样倒排后就可以从高分往低分来看名字;
通过这种方式可以得到一份符合自己孩子生辰八字、自己的家谱限制、以及自己喜好的名字列表,并且该列表已经给出了分数用于参考给新生宝宝起个名字,你真的了解吗?,以此为基准我们可以挨个琢磨找出心仪的名字。当然如果有新的想法,随时可以把新的名字添加到词库里面,进行重新计算。
程序的代码结构
代码介绍:
使用代码的方法:
如果没有限定字,就找到词典文件.txt和.txt,可以在这里添加自己找到的一些名字列表,按行分割添加在最后即可; 如果有限定字,就找到词典文件.txt和.txt,在这里添加自己预先中意的单个字列表,按行分割添加在最后即可; 打开.py,进行配置,配置项见下一节; 运行脚本.py 在目录中,查看自己的产出文件,可以复制到Excel,进行排序等操作; 程序的配置入口
程序的配置如下:
# :
"""
在这里写好配置
"""
= {}
# 限定字,如果配置了该值,则会取用单字字典,否则取用多字字典
[ ""] = "国"
# 姓
[ ""] = "李"
# 性别周易生辰八字测名字打分最准,取值为 男 或者 女
[ "sex"] = "男"
# 省份
[ ""] = "北京"
# 城市
[ ""] = "海淀"
# 出生的公历年份
[ 'year'] = "2017"
# 出生的公历月份
[ 'month'] = "1"
# 出生的公历日子
[ 'day'] = "11"
# 出生的公历小时
[ 'hour'] = "11"
# 出生的公历分钟
[ ''] = "11"
# 结果产出文件名称
[ ''] = "xx.txt"
根据配置项[“”],系统自动来决定选用单字词典还是多字词典:
程序的原理
这是一个简单的爬虫。大家可以打开网站查看,这是一个POST表单,填写需要的参数,点提交,就会打开一个结果页面,结果页面的最下方包含了八字分数和五格分数。
如果想得到分数,就需要做两件事情,一是爬虫自动提交表单,获取结果页面;二是从结果页面提取分数;
对于第一件事情,很简单,即可实现(代码在/-name-score/main/.py):
= .()
req = .(., )
= req. read()
这里的是个参数dict,使用这种方式,就进行了POST带数据的提交,然后从得到了结果数据。
的参数设定如下:
= {}
# 日期类型,0表示公历,1表示农历
[ ''] = "0"
[ 'year'] = "%s"% str(.[ "year"])
[ 'month'] = "%s"% str(.[ "month"])
[ 'day'] = "%s"% str(.[ "day"])
[ 'hour'] = "%s"% str(.[ "hour"])
[ ''] = "%s"% str(.[ ""])
[ 'pid'] = "%s"% str(.[ ""])
[ 'cid'] = "%s"% str(.[ ""])
# 喜用五行,0表示自动分析,1表示自定喜用神
[ 'wxxy'] = "0"
[ 'xing'] = "%s"% (.[ ""])
[ 'ming'] =
# 表示女,1表示男
.[ "sex"] == "男":
[ 'sex'] = "1"
else:
[ 'sex'] = "0"
[ 'act'] = ""
[ 'isbz'] = "1"
第二件事情,就是从网页中提取需要的分数,我们可以使用来实现周易生辰八字测名字打分最准,其语法也很简单:
soup = (, 'html.', = "")
= ()
# print soup.find(=pile(u"姓名五格评分"))
.( "div", = ""):
= node.()
ifu'姓名五格评分':
= node.find(=pile( u"姓名五格评分"))
[ ''] = ..b.()
ifu'姓名八字评分':
= node.find(=pile( u"姓名八字评分"))
[ ''] = ..b.()
通过该方法,就能对HTML解析,提取八字和五格的分数。
运行结果事例
1/1287 李国锦 姓名八字评分=61.5 姓名五格评分=78.6 总分=140.1
2/1287 李国铁 姓名八字评分=61 姓名五格评分=89.7 总分=150.7
3/1287 李国晶 姓名八字评分=21 姓名五格评分=81.6 总分=102.6
4/1287 李鸣国 姓名八字评分=21 姓名五格评分=90.3 总分=111.3
5/1287 李柔国 姓名八字评分=64 姓名五格评分=78.3 总分=142.3
6/1287 李国经 姓名八字评分=21 姓名五格评分=89.8 总分=110.8
7/1287 李国蒂 姓名八字评分=22 姓名五格评分=87.2 总分=109.2
8/1287 李国登 姓名八字评分=21 姓名五格评分=81.6 总分=102.6
9/1287 李略国 姓名八字评分=21 姓名五格评分=83.7 总分=104.7
10/1287 李国添 姓名八字评分=21 姓名五格评分=81.6 总分=102.6
11/1287 李国天 姓名八字评分=22 姓名五格评分=83.7 总分=105.7
12/1287 李国田 姓名八字评分=22 姓名五格评分=93.7 总分=115.7
有了这些分数,我们就可以进行排序,是一个很实用的参考资料。
友情提示
分数跟很多因素有关,比如出生时刻、已经限定的字、限定字的笔画等因素,这些条件决定了有些名字不会分数高,不要受此影响,找出相对分数高的就可以了; 目前程序只能抓取一个网站的内容,地址是 本列表仅供参考,看过一些文章,历史上很多名人伟人,姓名八字评分都非常低但是都建功立业,名字确实会有些影响但有时候朗朗上口就是最好的; 从本列表中选取名字之后,可以在百度、人人网等地方查查,以防有些负面的人重名、或者起这个名字的人太多了烂大街; 八字分数是中国传承,五格分数是日本人近代发明的,有时候也可以试试西方的星座起名法,并且奇怪的是八字和五个分数不同网站打分相差很大,更说明了这东西只供参考;
本文的代码已上传到:
支付宝扫一扫
微信扫一扫