利用Python为女神制作一个专属网站

打印 上一主题 下一主题

主题 847|帖子 847|积分 2541

 一、数据准备
首先是测试图片的获取,毕竟萝卜哥当前还没有那么多女神的照片
这里我使用如下网站的高清图片,嗯,各个都是大美女

 
 
 
抓取的代码比较简单
  1. import requests
  2. import json
  3. def get_pic():
  4.     headers = {"Accept": "application/json, text/javascript, */*; q=0.01",
  5.                "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 11_0_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4389.114 Safari/537.36",
  6.                "Cookie": "Hm_lvt_6e8dac14399b608f633394093523542e=1607173561; Hm_lvt_ea4269d8a00e95fdb9ee61e3041a8f98=1621344383; Hm_lpvt_ea4269d8a00e95fdb9ee61e3041a8f98=1621344423",
  7.                "Referer": "http://lab.mkblog.cn/wallpaper/"}
  8.     pic_url = "http://lab.mkblog.cn/wallpaper/api.php?cid=6&start=0&count=100"
  9.     pic_res = requests.get(pic_url, headers=headers)
  10.     pic_res_json = pic_res.json()
  11.     pic_info = pic_res_json.get("data")
  12.     pic_url = []
  13.     num = 0
  14.     try:
  15.         for i in pic_info:
  16.             if num % 5 == 0:
  17.                 pic_url.append(i["url"])
  18.             if num % 5 == 1:
  19.                 pic_url.append(i["img_1600_900"])
  20.             if num % 5 == 2:
  21.                 pic_url.append(i["img_1366_768"])
  22.             if num % 5 == 3:
  23.                 pic_url.append(i["img_1280_800"])
  24.             if num % 5 == 4:
  25.                 pic_url.append(i["img_1024_768"])
  26.             num += 1
  27.     except:
  28.         pass
  29.     return pic_url
  30. def save_pic_url(data):
  31.     json.dump(data, open("pic_url.json", 'w'))
  32. if __name__ == '__main__':
  33.     pic_url = get_pic()
  34.     save_pic_url(pic_url)
复制代码
因为网站提供了不同分辨率的图片,所以也就根据一定的规则来获取不同分辨率的图片了。
接下来是获取渣男话术,哈哈哈哈,又是一个有趣的网站,感兴趣的朋友自行查看吧
由于这个接口是有调用频率限制的,那么也抓取一些到本地吧
  1. def get_data():
  2.     headers = {"Accept": "application/xml",
  3.                "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 11_0_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4389.114 Safari/537.36"}
  4.     url = "https://nihaowua.90so.net/api/wus"
  5.     res = requests.get(url, headers=headers).json()
  6.     return res
  7. if __name__ == '__main__':
  8.     data_list = []
  9.     for i in range(10):
  10.         data = get_data()
  11.         data_list.append(data.get("title"))
  12.         time.sleep(10)
  13.     json.dump(data_list, open("data.json", "w"))
复制代码
二、网站搭建

首先我们还是通过简单的 Flask 来进行后台的搭建
index 视图
  1. @app.route('/', methods=['GET', 'POST'])
  2. def index():
  3.     pic_list = json.load(open("pic_url.json"))
  4.     seg = int(len(pic_list)/4)
  5.     data = []
  6.     socre = 5
  7.     for n in pic_list[:seg]:
  8.         tmp_data = []
  9.         pic_url = random.choice(pic_list)
  10.         tmp_data.append(pic_url)
  11.         tmp_data.append(pic_list.index(n))
  12.         data.append(tmp_data)
  13.     return render_template('index.html', data=data, score=socre)
复制代码
还是比较简单的,拿到图片地址文件中的数据后,根据规则展示一部分图片
下面是 index.html 的部分核心代码
图片展示代码
[code]{% for p in data %}                        <img class="thumb" data-original="{{ p[0] }}">                <a href="https://www.cnblogs.com/{{ url_for('nvshen', id=p[1]) }}" rel="external nofollow"  title="去投票" target="_blank">爱你
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

大号在练葵花宝典

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表