【python】10分钟教你用python如何正确把妹
前言
今天没妹子约,刚好研究一下。如何用神奇的python打造一个把妹神器吧。看完这个,你们就能走向人生巅峰,迎娶白富美啦。
我知道你们想看看效果
image
当然啦,这只是测试版的效果,真正的版本可比这个厉害多啦。不过作为一个直男,另一个男的给小编发这个测试感觉还是有点怪怪的哈。
文:吉柏言
暑假来了,各位又不得不和男女朋友暂时分开2个月了!!长达两个月的时间里不能相见,你可知我多想你啊,想知道你的城市下雨了吗,想知道你带伞了吗,想知道你长什么样,想知道你叫啥,咳咳,单身汪小编表示情绪稳定。
没关系,虽然不能见面,但是云关怀还是要到的嘛,每天查一查你那里的天气如何,送上作为男朋友的关切问候,再配上一张爱你的图片,噫~~。但是作为绝地鸡王那必须每晚吃鸡呀,早上醒来忘了打卡怎么办?? 能让机器干的活我们何必自己动手呢?当然可以走一波python大法好啦!
今天的代码我们要做得就是定点打卡,每天向亲爱的女票送去温暖的祝福~~,单身汪小编表示情绪稳定。
环境准备
首先,安装我们需要的库:
1import requests
2from bs4 import BeautifulSoup
3from email.mime.image import MIMEImage
4from email.mime.multipart import MIMEMultipart
5from email.mime.text import MIMEText
6from email.header import Header
7import smtplib
8import os
我们用requests + bs4 库进行爬取当日的天气状况以及我们需要的图片,用email库和smtplib库来发邮件,当中我们还需要os库对其他文件进行操作。
开始搞事
首先爬取天气状况和图片资源,我选择的是对中国气象台和豆瓣上一位名为名为“狼魄乾坤”的网友的豆瓣相册进行爬取,首先本着盗亦有道的原则,先查看robots协议。
image
image
很好,中央气象站没有robots协议,豆瓣也没有对相册加以限制,那么我们可以放心大胆地爬取了。
进入网站,查找一下她所在的城市,本汪没有女票就以自己所在的城市为例子了。
http://www.nmc.cn/publish/forecast/AHB/wuhan.html 。分析一下这个地址,发现对于城市的分类命名规则是A+省份简写如湖北(HB)以及城市拼音,对于一些比较模糊的省份简写小编附在下图的代码中:
1def main():
2# print("河北HE 内蒙古NM 陕西SN 黑龙江HL 河南HA")
3# province = input("input the province,the big alpha for short:")
4# city = input("input the city you wanna search plz:")
5 province = "HB"
6 city = "wuhan"
7 url = "http://www.nmc.cn/publish/forecast/A" + province + "/" + city + ".html"
8 html = getHTMLText(url)
9 url = "https://www.douban.com/photos/album/157693223/"
10 image = getHTMLText(url)
请忽略小编的辣鸡英文。
getHTMLText(url)是自定义方法,为的是获取网页的源代码,返回值为包含整个源代码的字符串:
1def getHTMLText(url):
2 try:
3 r = requests.get(url)
4 print(r.raise_for_status)
5 r.encoding = r.apparent_encoding
6 return r.text
7 except:
8 return ""
我们用requests.get(url)向网站提出爬取申请,用raise_for_status查看状态码,如果为200则说明爬取成功,然后我们用apparent_encoding替换掉encoding,这是让程序自己识别编码方式,保证返回的不是乱码。倘若爬取过程没有出错,就把爬下来的新鲜的天气信息素材返回给变量html。用同样的方法,我们获取新鲜的图片库的素材也用同样的方法,返回给变量image。
1 imagLink = []
2 whetherInfo = parserHTMLWeather(html)
3 name = 1
4 for image in imagLink:
5 print(image)
6 for image in imagLink:
7 downloadPicture(image,name)
8 name += 1
回到main方法,我们要声明一个imagLink的列表,用来存放每个图库中每个图的地址,whetherInfo用来存储解析后的html的信息。打印image确定地址返回无误,因为在图库的源码中有豆瓣自己的大图地址和图片的地址,我们需要的是图片地址,确定无误后就可以逐个进行下载图片资源了。
先来看解析天气信息的parserHTMLWeather方法:
1def parserHTMLWeather(html):
2 try:
3 dirt = {}
4 soup = BeautifulSoup(html,"html.parser")
5 place = soup.find(name = "head").find("title")
6 dirt["place"] = str(place.string).split("-")[0]
7 AnnoceTime = soup.find(name = 'div', attrs = {"class":"btitle"}).find("span")
8 dirt["AnnoceTime"] = str(AnnoceTime.string)
9 Everyday = AnnoceTime.find_parent().find_next_sibling().find_all(name = "div",class_ = "detail")
10 for eachday in Everyday:
11 info = eachday.find(name = "div",class_ = "day")
12 thisDay = {}
13 date = str(info.find(name = "div",class_ = "date").string)
14 week = str(info.find(name = "div",class_ = "week").string)
15 wdesc = str(info.find(name = "div",class_ = "wdesc").string)
16 temp = str(info.find(name = "div",class_ = "temp").string)
17 direct = str(info.find(name = "div",class_ = "direct").string)
18 wind = str(info.find(name = "div",class_ = "wind").string)
19
20 thisDay["date"] = date
21 thisDay["week"] = week
22 thisDay["wdesc"] = wdesc
23 thisDay["temp"] = temp
24 thisDay["direct"] = direct
25 thisDay["wind"] = wind
26 dirt[thisDay["date"]] = thisDay
27
28 return dirt
29 except:
30 return {}
首先先声明dirt为一个字典,然后把html用beautifulSoup库对其进行解析,解析后的soup对象可以调用它的find方法和find_all方法开始寻找我们需要的信息所对应的标签。至于哪个信息对应哪个标签,可以在浏览器中用ctrl + F的快捷键调出搜索框。获取到我们需要的信息后,我们可以把它进行加工保存在每天的thisDay字典里,然后再把7天的thisDay字典加入dirt字典里,最后返回dirt字典。具体的加工方法就是用split方法切片、提取。当然也可以选择正则表达式,需要额外再引用re库。
然后是解析图片:
1def parserHTMLPicture(imag,imagLink):
2 try:
3 soup = BeautifulSoup(imag,"html.parser")
4# next_url = soup.find(name = 'link',rel = 'next')['href']
5# next_page = getHTMLText(next_url)
6 imagAddress = soup.find(name='div',class_ = 'photolst clearfix').find_all(name = 'img')
7 for image in imagAddress:
8 imagLink.append(image['src'])
9
10 return imagLink
11 except:
12 return []
解析图片我们只需要把图片的地址获取到imagLink列表中即可。然后我们遍历这个列表,并且下载这些图片:
1def downloadPicture(url,name):
2 root = 'C:\\Users\\10990\\Pictures\\'#这里填保存的路径
3 path = root + str(name) + '.jpg'
4 try:
5 if not os.path.exists(root):
6 os.mkdir(root)
7 if not os.path.exists(path):
8 r = requests.get(url)
9 with open(path,'wb') as f:
10 f.write(r.content)
11 f.close()
12 print("文件保存成功")
13 else:
14 print("文件已存在")
15 except:
16 print("爬取失败")
在下载前我们要注意判断路径是否存在,若不存在要建立一个,在开始爬之前要留意是否已经爬取过,若已经存在则跳过。命名我是以数字顺序命名的,在后续调用中也更方便。
然后我们需要新建一个txt文件,用来保存本次发送的照片名字,注意该文件应该和代码的py文件保存在同一路径下。
回到main()方法
1with open('pictureName.txt','r') as f:
2 name = eval(f.read())
3 f.close()
4 with open('pictureName.txt','w') as f:
5 newName = str(name + 1)
6 f.write(newName)
7 f.close()
8 msgRoot = makeMessage(whetherInfo,name)
9sendMsg(msgRoot)
然后我们读取当前的图片名,赋给name,再把name名加一后重新保存下来,这样每天发给女票的就是一张新的图片了。然后要把我们的天气信息和我们每天想说的话以及图片打包成一个email对象发送出去就行啦。
1def makeMessage(dirt,image):
2 #编辑消息
3 print(dirt)
4 message = dirt["place"]+' 今天 '
5 items = {'wdesc','temp','direct','wind'}
6 for item in items:
7 message += dirt["\n 今天\n "][item].strip('\n ')+" "
8 for temp in message.split(" "):
9 if temp.find("℃") != -1:
10 if eval(temp.split("℃")[0]) > 25:
11 message += "今天很热,尽量别出门啦"
12 elif eval(temp.split("℃")[0]) < 12:
13 message += "今天很冷,注意保暖"
14 if message.find("雨") != -1:
15 message += " 出门的话记得带伞"
16 print(message)
17
18 #生成邮件对象
19 msgRoot = MIMEMultipart('related')
20 msgRoot['From'] = Header("我是发信人","utf-8")
21 msgRoot['To'] = Header('我是收信人','utf-8')
22 subject = '赴戍登程口占示家人'
23 msgRoot['Subject'] = Header(subject,'utf-8')
24
25 msgAlternative = MIMEMultipart('alternative')
26 msgRoot.attach(msgAlternative)
27
28 mail_msg = '''
29 <p> 力微任重久神疲,再竭衰庸定不支。
30 苟利国家生死以,岂因祸福避趋之?
31 谪居正是君恩厚,养拙刚于戍卒宜。
32 戏与山妻谈故事,试吟断送老头皮。
33 </p>
34 <p>'''+message+'''</p>
35 <p><img src = "cid:image1"></p>
36'''
37 msgAlternative.attach(MIMEText(mail_msg,'html','utf-8'))
38
39 catalog = 'C:\\Users\\10990\\Pictures\\' + str(image) + ".jpg"
40 #指定图片为当前目录
41 with open(catalog,'rb') as fp:
42 msgImage = MIMEImage(fp.read())
43 fp.close()
44
45 #定义图片在ID,在HTML文本中引用
46 msgImage.add_header('Content-ID','<image1>')
47 msgRoot.attach(msgImage)
48 return msgRoot
49
50def sendMsg(message):
51 mail_host = "smtp.qq.com"#要使用的smtp服务器
52 mail_user = "*******"#用户名和密码
53 mail_pass = "********"
54 sender = '********'#发送者
55 receivers = ['*******']#收信者,注意这里是一个列表,就是说可以群发,当然劝君莫浪~~
56 try:
57 smtpObj = smtplib.SMTP()
58 smtpObj.connect(mail_host)
59 smtpObj.ehlo()
60 smtpObj.starttls()
61 smtpObj.login(mail_user,mail_pass)
62 smtpObj.sendmail(sender,receivers,message.as_string())
63 print("邮件发送成功")
64 smtpObj.quit()
65 except smtplib.SMTPException:
66 print("Error:无法发送邮件")
往后都是可以从网上找到的代码,当然了各位也可以更进一步,从网上爬取各种骚话,用同样的方式解析并加入email对象中,为了不吃狗粮小编决定交给各位自己发掘(其实就是懒)需要注意,图片我们只爬取了一页的图片,各位还可以自行添加代码,完成自动换页之后的爬取,因为图片有限,当我们的txt文件数大于18,即自动发送18天后,需要另外爬取第二页的图片。
另外,推荐把程序挂到服务器上面,做个定时发送。每天准点发送。这样妹子就可以天天收到你的云关怀啦。
记得让女票把你加入白名单,否则你发过去的邮件都会被投进垃圾箱的。
完整代码
欲获取代码,请关注我们的微信公众号【程序猿声】,在后台回复:pylove。即可下载。
微信公众号
【python】10分钟教你用python如何正确把妹的更多相关文章
- 【python】10分钟教你用python打造贪吃蛇超详细教程
10分钟教你用python打造贪吃蛇超详细教程 在家闲着没妹子约, 刚好最近又学了一下python,听说pygame挺好玩的.今天就在家研究一下, 弄了个贪吃蛇出来.希望大家喜欢. 先看程序效果: 0 ...
- 10分钟教你用Python打造天气机器人+关键字自动回复+定时发送
01 前言 Hello,各位小伙伴.自上次我们介绍了Python实现天气预报的功能以后,那个小程序还有诸多不完善的地方,今天,我们再次来完善一下我们的小程序.比如我们想给机器人发“天气”等关键字,它就 ...
- 10分钟教你用Python打造微信天气预报机器人
01 前言 最近武汉的天气越来越恶劣了.动不动就下雨,所以,拥有一款好的天气预报工具,对于我们大学生来说,还真是挺重要的了.好了,自己动手,丰衣足食,我们来用Python打造一个天气预报的微信机器人吧 ...
- 10分钟教你用Python玩转微信之好友性别比例统计分析
01 前言+效果展示 想必,微信对于大家来说,是再熟悉不过的了.那么,大家想不想探索一下微信上的各种奥秘呢?今天,我们一起来简单分析一下微信上的好友性别比例吧~废话不多说,开始干活. 结果如下: 02 ...
- 10分钟教你用Python玩转微信之抓取好友个性签名制作词云
01 前言+展示 各位小伙伴我又来啦.今天带大家玩点好玩的东西,用Python抓取我们的微信好友个性签名,然后制作词云.怎样,有趣吧~好了,下面开始干活.我知道你们还是想先看看效果的. 后台登录: 词 ...
- 【python】10分钟教你用python下载和拼接微信好友头像图片
前言 相信微信大家是用得再多也不过了.那么,对于python+微信,又能玩出什么新的花样呢?下面小编就给大家带来一个好玩的东西.用python下载所有的微信好友的头像,然后拼接成一张大图.这样,大家就 ...
- 【python】10分钟教你用python一行代码搞点大新闻
准备 相信各位对python的语言简洁已经深有领会了.那么,今天就带大家一探究竟.看看一行python代码究竟能干些什么大新闻.赶紧抄起手中的家伙,跟我来试试吧. 首先你得先在命令行进入python. ...
- 10分钟教你用Python实现微信自动回复
01 前言&&效果展示 相信大家都有忙碌的时候,不可能一直守在微信上及时回复消息.但微信又不能像QQ一样设置自动回复.无妨,今天,我们就来用Python实现微信的自动回复功能吧,并且把 ...
- 【python】10分钟教你用Python做个打飞机小游戏超详细教程
更多精彩尽在微信公众号[程序猿声] 我知道你们一定想先看效果如何 00 目录 整体框架 开始之前-精灵类Sprite 子弹类class Bullet 玩家飞机类class Player 敌机类clas ...
随机推荐
- 超出div宽度范围的文字进行省略号省略,在鼠标移上去以后显示完整的内容
一.前言 当我们在固定的范围内显示内容时,我们是希望能够完整显示的,然而往往事与愿违,文本会超出我们给定的范围,这时候怎么办呢? 二.超出范围,对文本进行省略号隐藏 先上图 代码很简单 div{ wi ...
- Linux 基金会宣布联合 edX 提供免费 Linux 课程
edX 是一个由麻省理工学院和哈佛大学创建的大规模开放在线课堂平台.它免费给大众提供大学教育水平的在线课堂.” edX 学习平台” 就像 开源软件似的发展,它使得其它院校机构也可以提供其高级学习的 ...
- 单例模式的N种写法
单例模式算是设计模式中最容易理解,也是最容易手写代码的模式了吧.但是其中的坑却不少,所以也常作为面试题来考.本文主要对几种单例写法的整理,并分析其优缺点.很多都是一些老生常谈的问题,但如果你不知道如何 ...
- 2018年最新 Java面试通关要点汇总集
基础篇 基本功 面向对象的特征 final, finally, finalize 的区别 int 和 Integer 有什么区别 重载和重写的区别 抽象类和接口有什么区别 说说反射的用途及实现 说说自 ...
- String.getBytes()[转]
在Java中,String的getBytes()方法是得到一个操作系统默认的编码格式的字节数组.这个表示在不通OS下,返回的东西不一样! String.getBytes(String decode)方 ...
- ssh 连接缓慢解决方法
ssh 连接缓慢解决方法 摘自:https://blog.csdn.net/qq_14821541/article/details/61915589 2017年03月13日 12:00:38 所以怎样 ...
- 1045 Bode Plot
题目链接:http://poj.org/problem?id=1045 一道数学物理题, 推理公式:http://www.cnblogs.com/rainydays/archive/2013/01/0 ...
- xampp 添加ssl 访问
编辑php.ini 文件,找到 “;extension=php_openssl.dll” (去掉前面的;号注释) <VirtualHost *:8090> DocumentRoot &qu ...
- vscode填坑之旅: vscode设置中文,设置中文不成功问题
刚安装好的vscode界面显示中文,如何设置中文呢? 在locale.json界面设置”locale":"zh-cn"也未能实现界面为中文,在网上找了参考了,以下教程真实 ...
- C# 判断是否是在设计模式下有效的方法
public static bool IsDesignMode() { bool returnFlag = false; #if DEBUG if (LicenseManager.UsageMode ...