作者 | crazyant

原文 | https://github.com/peiss/chinese-name-score

访问flyai.club,创建你的人工智能项目。

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

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

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

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

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

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

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

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

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

程序的代码结构


代码介绍:

/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 程序的运行入口

使用代码的方法:

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

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

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

运行脚本 get_name_score.py

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

程序的配置入口

程序的配置如下:

# 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"] ,系统自动来决定选用单字词典还是多字词典:

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

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

程序的原理

这是一个简单的爬虫。大家可以打开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"

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

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.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

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

友情提示

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

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

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

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

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

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

访问flyai.club,创建你的人工智能项目。

Python | 宝爸宝妈不用愁,怎样给宝宝取个好名字?相关推荐

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

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

  2. 怎样用Python给宝宝取个好名字?

    点击上方"程序员大咖",选择"置顶公众号" 关键时刻,第一时间送达! 每个人一生中都会遇到一件事情,在事情出现之前不会关心,但是事情一旦来临就发现它极其重要,并 ...

  3. 利用python从网页查找数据_利用Python模拟淘宝的搜索过程并对数据进行可视化分析...

    数据挖掘入门与实战 公众号: datadw 本文讲述如何利用Python模拟淘宝的搜索过程并对搜索结果进行初步的数据可视化分析. 搜索过程的模拟:淘宝的搜索页面有两种形式, 一种形式是, 2019/2 ...

  4. Python实现淘宝卖家价格分析,淘宝卖家必会的操作!

    淘宝卖家必备程序 前一阵闲的冒泡开了个淘宝店,因为改价格等各种原因麻烦的不得了,这不就心思爬个虫懒得一页页翻了么! 如果你没开过淘宝店或者非得自己亲眼看网页价格,那么这篇咱们就没啥缘分了,我们以后随缘 ...

  5. Python爬虫模拟浏览器的headers、cookie,爬取淘宝网商品信息

    一. 淘宝商品信息定向爬虫 二. 爬虫基础:正则表达式 三. 淘宝页面查看与分析 四. 爬虫源码 一. 淘宝商品信息定向爬虫 注意淘宝的robots.txt不允许任何爬虫爬取,我们只在技术层面探讨这一 ...

  6. 【数据分析】系列-Python分析淘宝4200款Bra(没错,就是文胸)后,发现最好卖的款式居然是。。。

    此博客仅为我业余记录文章所用,发布到此,仅供网友阅读参考,如有侵权,请通知我,我会删掉. 本着娱乐的态度,着手分析一下淘宝的前4200+款bra(文胸),看看有什么有趣的地方. 项目背景 起因:近日, ...

  7. 用python实现淘宝毫秒级秒!! 天猫淘宝的抢购完美实现 而且说实话有很多人需要它。 每次在抢购前的无法提交订单导致很多买家无法购买。 今天我教给大家如何更好快速实现你的购买愿望! 教程如下!请仔

    用python实现淘宝毫秒级秒!! 天猫淘宝的抢购完美实现 而且说实话有很多人需要它. 每次在抢购前的无法提交订单导致很多买家无法购买. 今天我教给大家如何更好快速实现你的购买愿望! 教程如下!请仔细 ...

  8. 如何秒下单?python的淘宝秒杀抢购下单源码参考

    如何秒下单?python的淘宝秒杀抢购下单源码参考 疫情如期,隔离还在继续,何时工作是一个头大的问题,最近在看口罩,不少电商平台都有放出口罩,当然,手残党将会也会是一直难以下手,你可能很难抢得到,故找 ...

  9. python写淘宝秒杀脚本_python实现淘宝秒杀脚本

    本文实例为大家分享了python实现淘宝秒杀脚本的具体代码,供大家参考,具体内容如下 1.安装pycharm.网上教程很多. 2.安装 Selenium 库. Selenium支持很多浏览器,我选择的 ...

最新文章

  1. Unity3D:中小型团队游戏研发的突围之道
  2. mysql数据库什么是事件_MySQL数据库之mysql 事件(Event) 总结
  3. 提高Web性能的前端优化技巧总结
  4. 如何将APACHE许可证应用于您的工作
  5. 使用js 调用 google ads
  6. 【7集iCore3基础视频】7-4 iCore3连接示意图
  7. EntityFramework之DetectChanges's Secrets(三)(我为EF正名)
  8. appium+python环境搭建_想学习自动化测试,已经学习了appium+python环境搭建和python的简单内容,下面该怎么做?...
  9. 用银行卡号查相应的归属银行,卡种类
  10. 2022上半年朋友圈都在传的10本书,找到了
  11. elasticsearch 使用
  12. nginx配置长链接
  13. 计算机专业裁合词英语,计算机专业英语的构词方法
  14. 警惕邮件中的发票链接
  15. 《绝版游戏之信长之野望12—“统一日本的游戏“》
  16. oracle 纵列 转 横列,oracle sql小结(主要讲横列转换的例子)decode 以及case
  17. 服务器运行时将杀毒软件关掉,云服务器的速度性能优化之一(关闭Windows杀毒软件及无关服务及程序)...
  18. java ajax serialize,jQuery使用serialize(),serializeArray()方法取得表单数据
  19. 如何快速找出电脑里的所有视频\照片\文件
  20. 项目:淘宝用户数据分析

热门文章

  1. Zeus资源调度系统介绍
  2. BZOJ4706 B君的多边形 (超级卡特兰数/施罗德数)
  3. python多进程优化_Python 的多进程,考虑到会发生死进程,如何收敛结束,安全又方便?...
  4. Quill编辑器内置样式配置
  5. 淘宝/天猫邻家好货 API 返回值说明
  6. Sequelize ORM
  7. 高级转录组分析和R数据可视化技术研讨会(2023.2)
  8. 【夜读】这一年,谢谢自己
  9. C++语言篇 第五章 一维数组
  10. Android 基础 UI 界面设计