整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

程序猿打造最强表白程序,网友看后:还有这种操作?

程序猿打造最强表白程序,网友看后:还有这种操作?

人节刚过,朋友圈又是刷屏的节奏。但热闹总是别人的,我们好像只有吃狗粮的份。时间总是飞快流逝,很多事情早已改变,但仿佛只有你的单身状态从未改变。

单身久的我们,好像觉得一个人过也没什么的。但即使非常享受单身生活,大家也要保持“可勾搭”的待机状态,因为促进荷尔蒙分沁有益身心健康。

在这个人人都在秀的时候,做为程序员我们也要操作起来!散发你们的荷尔蒙!今天就大家奉献上最强表白程序!此程序结合数据抓取 + 微信自动发消息 + 定时任务,实现一个能每天自动定时给你心爱的 ta 发送:你们相识相恋天数 + 情话 + 我爱你的图片。具体的消息如下。



每天发送的消息格式如下:

 message="""
 亲爱的{}:
 早上好,今天是你和 Koc 相恋的第 {} 天~
 今天他想对你说的话是:
 {}
 最后也是最重要的!
 """.format("你的好友名称", str(inLoveDays), love_word)

这里需要填写的第一个字段是 ta 的称呼,inLoveDays 为你们相识相恋的天数。

love_word 是每天为 ta 精心准备情话内容,当然如果你的文笔好也可以自己写。

当然最后也是最重要的!每天不尽相同的「我爱你」图片!

程序思路

本次程序运行的环境是 windows10 + Python 3.6,此次主要用到的库有 selenium、itchat、request。程序主要分为两部分第一数据的抓取,一些情话信息和图片信息。另一部就是利用 itchat 自动发送消息给你的好友。

情话信息

如果对你的文笔有信心,那你可以自己写些情话。当然大部分人的文笔跟我一样是比较差的,所以这时候我们就可以利用网上的资源,比如下面的情话网站。

http://www.binzz.com/yulu2/3588.html

在抓取这个网站的情话时,如果你利用普通的爬取思路,即利用 request 进行请求,你会发现网页获取的数据是乱码并且不完整。所以在这块为了操作方便,我利用了 selenium 的 PhantomJS 无头浏览器,来获取网站的信息。

通过 selenium + xpath 我们就可以很轻松的获取到网页情话,最后把获取到的数据保存到当前目录下的「love_word.txt」方便之后的读取。

表白图片资源

为了配合此次表白程序,我专门去找了些带有「我爱你」的图片资源。通过下面的贴吧贴子,我们就可以获取到大量的这样资源。

http://tieba.baidu.com/p/3108805355

此贴并没有很强的反爬措施,所以我简单的利用 request + re 来获取到图片资源,并保存到当前目录的下「img」文件里。

在保存图片资源之前,我会先检查当前目录下是否有「img」文件夹,如果没有则会自动创建。

表白程序源码

此次表白程序主要有 5 个函数

crawl_Love_words()

此函数通过 selenium + xpath 来抓取情话网站的资源,并存入到当前目录下的「love_word.txt」文件。

def crawl_Love_words():
 print("正在抓取情话...")
 browser=webdriver.PhantomJS()
 url="http://www.binzz.com/yulu2/3588.html"
 browser.get(url)
 html=browser.page_source
 Selector=etree.HTML(html)
 love_words_xpath_str="//div[@id='content']/p/text()"
 love_words=Selector.xpath(love_words_xpath_str)
 for i in love_words:
 word=i.strip("\n\t\u3000\u3000").strip()
 with open(love_word_path, "a") as file:
 file.write(word + "\n")
 print("情话抓取完成")

crawl_love_image()

此函数用来爬取贴吧带有「我爱你」的图片资源,通过 request + re 来实现。代码并不复杂,在正则表达式那也简单的写了一个,用来匹配当前也所有的图片资源。

def crawl_love_image():
 print("正在抓取我爱你图片...")
 for i in range(1, 22):
 url="http://tieba.baidu.com/p/3108805355?pn={}".format(i)
 response=requests.get(url)
 html=response.text
 pattern=re.compile(r'<div.*?class="d_post_content j_d_post_content.*?">.*?<img class="BDE_Image" src="(.*?)".*?>.*?</div>', re.S)
 image_url=re.findall(pattern, html)
 for j, data in enumerate(image_url):
 pics=requests.get(data)
 mkdir(pic_path)
 fq=open(pic_path + '\\' + str(i) + "_" + str(j) + '.jpg', 'wb') # 下载图片,并保存和命名
 fq.write(pics.content)
 fq.close()
 print("图片抓取完成")


mkdir(path)

此函数用来在当前目录下创建一个新的文件夹,以便存储相应的数据。

def mkdir(path):
 folder=os.path.exists(path)
 if not folder: # 判断是否存在文件夹如果不存在则创建为文件夹
 os.makedirs(path) # makedirs 创建文件时如果路径不存在会创建这个路径
 print("--- new folder... ---")
 print("--- OK ---")
 else:
 print("正在保存图片中...")


send_new()

此函数通过利用 itchat 库,实现给你的微信好友自动发送消息。在这个函数中我利用 datetime 来计算你们之间相识相恋的时间。并且在登录的时候添加了一个「hotReload=True」,这样你就可以不用每次运行程序的时候都要登录。关于 itchat 更多的操作,大家可以去网上查找相应的资料。

def send_news():
 # 计算相恋天数
 inLoveDate=datetime.datetime(2018, 8, 15) # 相恋的时间
 todayDate=datetime.datetime.today()
 inLoveDays=(todayDate - inLoveDate).days
 # 获取情话
 file_path=os.getcwd() + '\\' + love_word_path
 with open(file_path) as file:
 love_word=file.readlines()[inLoveDays].split(':')[1]
 itchat.auto_login(hotReload=True) # 热启动,不需要多次扫码登录
 my_friend=itchat.search_friends(name=u'你的好友名称')
 girlfriend=my_friend[0]["UserName"]
 print(girlfriend)
 message="""
 亲爱的{}:
 早上好,今天是你和 Koc 相恋的第 {} 天~
 今天他想对你说的话是:
 {}
 最后也是最重要的!
 """.format("你的好友名称", str(inLoveDays), love_word)
 itchat.send(message, toUserName=girlfriend)
 files=os.listdir(pic_path)
 file=files[inLoveDays]
 love_image_file="D:\\img\\" + file
 try:
 itchat.send_image(love_image_file, toUserName=girlfriend)
 except Exception as e:
 print(e)


main()

main() 函数就是我们主逻辑函数,程序运行的逻辑顺序就是在这个函数里规定的。在 main() 里我首先判断下当前路径下是否有「love_word.txt」文件,如果有则提示相应的信息,没有的话才去执 crawl_Love_words() 函数,去网上抓取一些情话数据。

其次再判断下当前目录下是否有「img」文件夹,用来判断我们是否有图片资源,没有则执行 crawl_love_image() 来抓取贴吧上的图片资源。

最后我们所需的数据都已准备完善,则调用 send_news() 函数,整理下要发送的数据格式,然后自动给你的 ta 发送消息。

定时任务

每天定时发送我主要是用 while True 简单的实现,通过判断当前的时间是否是你所需要发送的时间,来达到每天定时发送。

表白程序使用教程

首先你把相应的源码下载下来,后台回复「表白」即可获取。其次把相应的库先事先安装好,随后运行程序则会显示一个微信网页登录的二维码,扫描登录即可。


因为我在登录时添加了「hotReload=True」,所以程序在下次运行时就无需再重新登录。

总结


文章标题写着「最强表白程序」,虽然有点夸张了,但此次的程序还有很多可以继续添加的地方。比如对于发送的消息字段,我们还可以继续添加天气信息、星座信息、娱乐新闻、最近的趣事、最近好看的电影等等。只要你能想到的内容,都可以添加上去。

这些信息在网上都可以获取的到,我们只要通过同样的思路,先抓取到本地,然后进行读取。当然如果你觉得存储本地会有被删的风险,那么你也可以保存到云端,在云端上进行存储。


看电脑性别

难道真的不想看看你整天对着的电脑.做着不可描述的事,也不想了解了下它的性别?难道人类就是这么狠心吗?/(ㄒoㄒ)/~~

接下打开你万能的记事本.写入这段代码: CreateObject("SAPI.SpVoice").Speak"你猜猜我是男是女"

随便改个文件名,后缀为vbs即可(栗子:xx.vbs) .点击它就OK了


HTML常用mete解释

mete标签就是对不可解释的解释.

ahtuor:我是MM

<meta name="author" content="我是一个漂亮的MM" />

keywords:求认识

<meta name="keywords" content="节操,MM,漂亮的MM" />

desciption:聊聊吧

<meta name="keywords" content="这是一个有节操的网站,求度娘,谷歌认了我这个可爱的MM,其他搜索引擎DIAO都不DIAO" />

robots:先摸下我底线吧

<meta name="keywords" content="all" />

all : 文件将被检索

none : 文件不被检索,页面链接可以被查询

index : 文件将被检索

follow : 页面链接允许查询

noindex : 文件不被检索,链接允许查询

nofloow : 文件允许检索,链接不允许查询

refresh:换个姿势吧

meta http-equiv="refresh" content="1;url=www.annsn.com" />
听我解释:不听.我不听
content内的数字代表秒数.url代表跳转的地址.这个mete功能标签叫做重定向
搜索引擎能够自动检测重定向,由于不能指定重定向原因.如302.404
不给搜索引擎解释的话,它就不能友好跟我们的做朋友了

viewport:让你的朋友认识我吧!

<meta name="viewport" content="width=device-width; initial-scale=1.0;maximum-scale=1.0; user-scalable=no;"/>

适用于移动设备

initial-scale : 初始缩放比例.范围0-10

minimun-scale :允许缩放最小比例

maximum-scale :允许缩放最大比例

user-scalable : 使用可以手动缩放no或者yes

apple-mobile-web-app-title:看名字就很DIAO了,只适合APPLE

apple-itunes-app

<meta name="apple-mobile-web-app-title" content="拿出你的IPhone就知道有什么用了">
主屏标题
<mete name='apple-itunes-app" content='myappstoreid,affiliate-date=myaffiliatedate,app-argument=myurl">
如果你在appstore上架程序,可以在别人网站时显示引导安装你程序

telephone和email

<meta content="telephone=no" name="format-detection" /> 
是否识别手机号和邮箱

cache-control:不要随便改变我

<meta http-equiv="Cache-Control" content="no-siteapp" />
避免百度转码.必须会对对移动端不友好的网页进行转码.

╮(╯▽╰)╭不写了,感觉这些太无聊了.还有设置编码.浏览器内核控制.QQ,微信等.参考QQ浏览器内核标签说明

点击右上角“关注”,关注小编我的头条号,及时接收精彩内容。文末可以领取编程资料

近日,小编在知乎上无意之间看到了这样帖子,如下图

对于这样的情况,小编觉得挺可惜的。多少次的怦然心动才换来一次付之行动,却因为各种各样的原因擦肩而过!到底要遇到多少在人生中途下车的人,才能遇到对的人。

相信不少在品读本文的读者也会遇到这样的事情,也许成功收获爱情,也许情深缘浅、也许情浅缘深...

不过,大家所最希望发生的事情肯定是有情人终成眷属,而不是握不住的沙那就扬了她。既然这样,那就看看下面的内容吧!!!

导出所有qq聊天记录,然后使用Python词云库做成女朋友的背景词云

虽然不一定费尽心思,倾尽家财,但是却是你们之间一点一滴的拼凑。哪里来的这么多轰轰烈烈,其实不都是生活的点点滴滴吗?只是长而相伴,久而情深罢了...

vbs表白

相信一定会给她惊喜的吧!

每天都不会缺少的微信表白:爱她就告诉她

代码格式如下:

message=""" 亲爱的{}: 早上好,今天是你和 Koc 相恋的第 {} 天~ 今天他想对你说的话是: {} 最后也是最重要的! """.format("你的好友名称", str(inLoveDays), love_word)

love_word 就是每天的情话,自己写的话可能更好一点哦!当然,并不是所有人都文笔不错,如果文笔一般的话可以利用 selenium 的 PhantomJS 无头浏览器,来获取网站的信息。通过 selenium + xpath 我们就可以获取到网页情话,最后把获取到的数据保存到当前目录下的「love_word.txt」方便之后的读取。

这个表白程序主要有5个函数

crawl_Love_words()
def crawl_Love_words(): print("正在抓取情话...") browser=webdriver.PhantomJS() url="http://www.binzz.com/yulu2/3588.html" browser.get(url) html=browser.page_source Selector=etree.HTML(html) love_words_xpath_str="//div[@id='content']/p/text()" love_words=Selector.xpath(love_words_xpath_str) for i in love_words: word=i.strip("\\u3000\\u3000").strip() with open(love_word_path, "a") as file: file.write(word + "") print("情话抓取完成")
crawl_love_image()
def crawl_love_image(): print("正在抓取我爱你图片...") for i in range(1, 22): url="http://tieba.baidu.com/p/3108805355?pn={}".format(i) response=requests.get(url) html=response.text pattern=re.compile(r'.*?.*?', re.S) image_url=re.findall(pattern, html) for j, data in enumerate(image_url): pics=requests.get(data) mkdir(pic_path) fq=open(pic_path + '\\' + str(i) + "_" + str(j) + '.jpg', 'wb') # 下载图片,并保存和命名 fq.write(pics.content) fq.close() print("图片抓取完成")
mkdir(path)
def mkdir(path): folder=os.path.exists(path) if not folder: # 判断是否存在文件夹如果不存在则创建为文件夹 os.makedirs(path) # makedirs 创建文件时如果路径不存在会创建这个路径 print("--- new folder... ---") print("--- OK ---") else: print("正在保存图片中...")
send_new()
def send_news(): # 计算相恋天数 inLoveDate=datetime.datetime(2018, 8, 15) # 相恋的时间 todayDate=datetime.datetime.today() inLoveDays=(todayDate - inLoveDate).days # 获取情话 file_path=os.getcwd() + '\\' + love_word_path with open(file_path) as file: love_word=file.readlines()[inLoveDays].split(':')[1] itchat.auto_login(hotReload=True) # 热启动,不需要多次扫码登录 my_friend=itchat.search_friends(name=u'你的好友名称') girlfriend=my_friend[0]["UserName"] print(girlfriend) message=""" 亲爱的{}: 早上好,今天是你和 Koc 相恋的第 {} 天~ 今天他想对你说的话是: {} 最后也是最重要的! """.format("你的好友名称", str(inLoveDays), love_word) itchat.send(message, toUserName=girlfriend) files=os.listdir(pic_path) file=files[inLoveDays] love_image_file="D:\\img\\" + file try: itchat.send_image(love_image_file, toUserName=girlfriend) except Exception as e: print(e)
main()

main() 函数就是我们主逻辑函数,程序运行的逻辑顺序就是在这个函数里规定的。在 main() 里我首先判断下当前路径下是否有「love_word.txt」文件,如果有则提示相应的信息,没有的话才去执 crawl_Love_words() 函数,去网上抓取一些情话数据。

路遥知马力,就算石头心,也该被你给打动了吧!

虽然方法不多,但是希望能帮到你们。

喜欢小编文章的可以点个赞关注小编哦,小编每天都会给大家更新文章。

我自己是一名从事了多年的Python老程序员,小编为大家准备了7月份新出的python编程学习资料,免费分享给大家!

如果你也想学习Python,那么帮忙转发一下然后再关注小编后私信“01”可以得到我整理的这些Python资料了(私信方法:点击我头像进我主页有个上面有个私信按钮)