前言

相信每位家长都有所体会,因为要在孩子出生后两周内起个名字(需要办理出生证明了),估计很多人都像我一样,刚开始是很慌乱的,虽然感觉汉字非常的多随便找个字做名字都行,后来才发现真不是随便的事情,怎么想都发现不合适,于是到处翻词典、网上搜、翻唐诗宋词、诗经、甚至武侠小说,然而想了很久得到的名字,往往却受到家属的意见和反对,比如不顺口、和亲戚重名重音等问题,这样就陷入了重复寻找和否定的循环,越来越混乱。
于是我们再次回到网上各种搜索,找到很多网上给出的“男宝宝好听的名字大全”之类的文章,这些文章一下子给出几百上千个名字,看的眼花缭乱没法使用。而有不少的测名字的网站或者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.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
有了这些分数,我们就可以进行排序,是一个很实用的参考资料。
友情提示
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家学习或使用python能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
# python
# 宝宝起名字
# 爬虫
# 网络爬虫
# Python之日期与时间处理模块(date和datetime)
# 使用PyV8在Python爬虫中执行js代码
# 关于Python面向对象编程的知识点总结
# 利用python程序生成word和PDF文档的方法
# Python中类型检查的详细介绍
# Python 模块EasyGui详细介绍
# Python爬虫:通过关键字爬取百度图片
# Python 遍历列表里面序号和值的方法(三种)
# 李国
# 在这里
# 多字
# 自己的
# 的人
# 就可以
# 网上
# 是从
# 这是一个
# 诗经
# 个字
# 该项
# 表单
# 的是
# 是一个
# 就会
# 是个
# 喜用
# 出了
# 最好的
相关文章:
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
建站之星如何快速生成多端适配网站?
如何在新浪SAE免费搭建个人博客?
如何用已有域名快速搭建网站?
Python多线程使用规范_线程安全解析【教程】
制作门户网站的参考文献在哪,小说网站怎么建立?
微课制作网站有哪些,微课网怎么进?
*服务器网站为何频现安全漏洞?
网站制作企业,网站的banner和导航栏是指什么?
Python路径拼接规范_跨平台处理说明【指导】
制作国外网站的软件,国外有哪些比较优质的网站推荐?
如何在阿里云香港服务器快速搭建网站?
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
唐山网站制作公司有哪些,唐山找工作哪个网站最靠谱?
如何通过IIS搭建网站并配置访问权限?
javascript基本数据类型及类型检测常用方法小结
如何通过VPS建站实现广告与增值服务盈利?
桂林网站制作公司有哪些,桂林马拉松怎么报名?
做企业网站制作流程,企业网站制作基本流程有哪些?
建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略
建站之星免费模板:自助建站系统与智能响应式一键生成
已有域名和空间,如何快速搭建网站?
建站之星后台管理系统如何操作?
广州建站公司哪家好?十大优质服务商推荐
php条件判断怎么写_ifelse和switchcase的使用区别【对比】
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
音乐网站服务器如何优化API响应速度?
实例解析angularjs的filter过滤器
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
如何快速配置高效服务器建站软件?
高端企业智能建站程序:SEO优化与响应式模板定制开发
C#怎么创建控制台应用 C# Console App项目创建方法
长沙企业网站制作哪家好,长沙水业集团官方网站?
,sp开头的版面叫什么?
怎么将XML数据可视化 D3.js加载XML
湖北网站制作公司有哪些,湖北清能集团官网?
活动邀请函制作网站有哪些,活动邀请函文案?
建站之星24小时客服电话如何获取?
电商网站制作价格怎么算,网上拍卖流程以及规则?
建站之家VIP精选网站模板与SEO优化教程整合指南
宝塔Windows建站如何避免显示默认IIS页面?
如何通过可视化优化提升建站效果?
大连网站设计制作招聘信息,大连投诉网站有哪些?
如何通过商城自助建站源码实现零基础高效建站?
电商平台网站制作流程,电商网站如何制作?
焦点电影公司作品,电影焦点结局是什么?
如何用y主机助手快速搭建网站?
内网网站制作软件,内网的网站如何发布到外网?
宝塔面板如何快速创建新站点?
家具网站制作软件,家具厂怎么跑业务?
*请认真填写需求信息,我们会在24小时内与您取得联系。