Python爬虫实战,requests+xlwings模块,Python实现制作天气预报表!

news2024/10/2 12:19:27

前言

今天为大家介绍Python+Excel的实战项目,非常有趣,废话不多说。

Let’s start happily

开发工具

Python版本: 3.6.4

相关模块:

xlwings模块

requests模块

pathlib模块

xlwings模块

json模块

环境搭建

安装Python并添加到环境变量,pip安装需要的相关模块即可。

文中完整版代码,评论留言获取。

具体操作可以看下图~

效果
在城市栏输入杭州,点击查询按钮,表格的数据就会发生变化,的确是杭州的天气预报。

① 数据获取

既然是天气预报,那肯定是需要天气数据的。

找了一圈国内开放的天气API接口,大多都是需要注册,小F果断放弃。

腾讯倒是有个不错的,可惜接口信息不太完整,没有相应的数据说明。

地址:https://tianqi.qq.com/

接口地址:https://wis.qq.com/weather/common

天气接口
最终选择了一个国外的天气API接口。

地址:https://www.metaweather.com/zh/
天气API接口
并没有提供国内所有的城市,目前只有10个城市。

所以要想城市多一些,腾讯的天气接口还是可以考虑的。

一共是有10种天气状态,并且提供了相关的天气状态图片,可以供我们使用。

图片已经下载下来了,需要的小伙伴可以文末获取哦!
天气状态
首先通过查询,获取城市的ID值。
城市的ID值
然后根据ID值,再去获取对应的天气信息。
对应的天气信息
相关名称的中英文对照如下。

# 天气--中英文名对照
weather = {
    'Snow': '雪',
    'Sleet': '雨夹雪',
    'Hail': '冰雹',
    'Thunderstorm': '雷阵雨',
    'Heavy Rain': '大雨',
    'Light Rain': '小雨',
    'Showers': '阵雨',
    'Heavy Cloud': '阴',
    'Light Cloud': '多云',
    'Clear': '晴'
}

# 城市--中英文名对照
citys = {
    '北京': 'Beijing',
    '成都': 'Chengdu',
    '东莞': 'Dongguan',
    '广州': 'Guangzhou',
    '杭州': 'Hangzhou',
    '香港': 'Hong Kong',
    '上海': 'Shanghai',
    '深圳': 'Shenzhen',
    '天津': 'Tianjin',
    '武汉': 'Wuhan'
}

② 创建表格

安装xlwings库,并且使用命令行创建项目。

# 安装xlwings
pip install xlwings -i https://mirror.baidu.com/pypi/simple/

# 命令行运行
xlwings quickstart weatherapp --standalone

如此便会生成两个文件,Python和Excel文件。
Python和Excel文件
其中weatherapp.py的文件内容如下。
weatherapp.py
上图为Mac电脑的设置,Windows电脑设置起来也很简单,具体可以百度。

通过点击开发工具选项,我们可以使用Excle的Visual Basic 编辑器(VBA),还能插入按钮(查询按钮)。
Visual Basic 编辑器
然后我在表格中插入一个点击按钮。
插入点击按钮
选择宏名称为SampleCall,宏的位置为当前工作簿。
SampleCall
点击按钮1,A1单元格出现内容Hello xlwings!。
Hello xlwings!
再次点击,A1单元格内容变为Bye xlwings!。
Bye xlwings!
也就意味着,修改weatherapp.py文件的代码,即可实现Excel的交互操作。

下面对表格进行页面设计,毕竟要让表格好看起来。
表格进行页面设计
设置表格的行高、列宽、背景色、固定文字内容等信息。

将单元格C3名称设置为city_name,插入6张太阳图片,排列在单元格C9~H9处,居中对齐,图片也改名为no.1~no.6。

修改weatherapp.py文件代码如下。

import json
from pathlib import Path
import requests
import xlwings as xw

# 天气--中英文名对照
weather = {
    'Snow': '雪',
    'Sleet': '雨夹雪',
    'Hail': '冰雹',
    'Thunderstorm': '雷阵雨',
    'Heavy Rain': '大雨',
    'Light Rain': '小雨',
    'Showers': '阵雨',
    'Heavy Cloud': '阴',
    'Light Cloud': '多云',
    'Clear': '晴'
}

# 城市--中英文名对照
citys = {
    '北京': 'Beijing',
    '成都': 'Chengdu',
    '东莞': 'Dongguan',
    '广州': 'Guangzhou',
    '杭州': 'Hangzhou',
    '香港': 'Hong Kong',
    '上海': 'Shanghai',
    '深圳': 'Shenzhen',
    '天津': 'Tianjin',
    '武汉': 'Wuhan'
}


def main():
    # 通过runpython从excel中调用python函数
    wb = xw.Book.caller()
    sht = wb.sheets[0]

    # 从Excel中读取城市信息
    city_name = citys[sht.range("city_name").value]

    # 获取城市的ID值, 即woeid
    URL_CITY = f"https://www.metaweather.com/api/location/search/?query={city_name}"
    response_city = requests.request("GET", URL_CITY)
    city_title = json.loads(response_city.text)[0]["title"]
    city_id = json.loads(response_city.text)[0]["woeid"]

    # 获取城市的天气信息
    URL_WEATHER = f"https://www.metaweather.com/api/location/{city_id}/"
    response_weather = requests.request("GET", URL_WEATHER)
    weather_data = json.loads(response_weather.text)["consolidated_weather"]

    # 创建空列表, 存储数据
    min_temp = []
    max_temp = []
    weather_state_name = []
    weather_state_abbr = []
    applicable_date = []

    # 处理数据
    for index, day in enumerate(weather_data):
        # 最低温度
        min_temp.append(weather_data[index]["min_temp"])
        # 最高温度
        max_temp.append(weather_data[index]["max_temp"])
        # 天气情况
        weather_state_name.append(weather[weather_data[index]["weather_state_name"]])
        # 天气情况缩写
        weather_state_abbr.append(weather_data[index]["weather_state_abbr"])
        # 日期
        applicable_date.append(weather_data[index]["applicable_date"])

    # 将获取到的值填充到Excel中
    sht.range("C5").value = applicable_date
    sht.range("C6").value = weather_state_name
    sht.range("C7").value = max_temp
    sht.range("C8").value = min_temp
    sht.range("D3").value = city_title

    # 创建列表
    icon_names = ["no.1", "no.2", "no.3", "no.4", "no.5", "no.6"]

    # 设置天气图片路径
    icon_path = Path(__file__).parent / "images"

    # 将天气情况与天气图片进行匹配,更新表格
    for icon, abbr in zip(icon_names, weather_state_abbr):
        image_path = Path(icon_path, abbr + ".png")
        sht.pictures.add(image_path, name=icon, update=True)


if __name__ == "__main__":
    # 设置用于调试caller()的excel文件,可以直接在python里运行
    xw.Book("weatherapp.xlsm").set_mock_caller()
    main()

在这里插入图片描述

此时我们打开Excel表格,在城市栏输入10个城市中的一个,然后点击查询按钮,天气就会更新。
接下来几天,广州都是大暴雨,广州的小伙伴可要注意了~

好了,本期的分享就到此结束了,有兴趣的小伙伴可以自行去实践学习。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/54414.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

RAR压缩包,去除密码?

压缩包设置了加密,需要输入压缩包密码才能够顺利解压文件出来。但是有些时候,一些文件只需要一段时间内要加密,之后文件不需要加密了,每次解压文件的时候还是需要输入压缩包密码才行,就很麻烦,那么RAR压缩包…

SAP 接口主动推送企业微信异常消息

"推送企业微信格式lv_json { "msgtype": "markdown", "markdown": &&{ "content": "### 异常JOB通知\n >JOB名称: && gt_alv-jobname && \n 程序名称: && gt_…

戟星安全实验室|五分钟教你挖掘小程序漏洞

戟星安全实验室 忆享科技旗下高端的网络安全攻防服务团队.安服内容包括渗透测试、代码审计、应急响应、漏洞研究、威胁情报、安全运维、攻防演练等。 本文约1252字,阅读约需5分钟。 前言 现在大多小程序反编译教程所使用的都是node.js,操作过程较为麻烦…

第一周练习——认识复杂度和简单排序算法

前言: 👏作者简介:我是笑霸final,一名热爱技术的在校学生。 📝个人主页:个人主页1 || 笑霸final的主页2 📕系列专栏:《数据结构与算法》 📧如果文章知识点有错误的地方&a…

Mediapipe学习记录

学习文档 1、Google MediaPipe:设备端机器学习【完整解决方案】背后的技术实现 - 极术社区 - 连接开发者与智能计算生态 2、【转载】Google MediaPipe:设备端机器学习【完整解决方案】背后的技术实现 3、MediaPipe框架结构 - 走看看 Handtracking封装…

qt creator 设置 项目依赖关系

qt creator中有两种设置项目依赖关系的方式。 1、对于有依赖的项目,如果工程比较简单,可以将所有项目放到一个空的项目下,然后显示地指定从属关系,参考:qmake TEMPLATE subdirs_丘上人的博客-CSDN博客 2、通过qt cre…

leecode#Excel表列序号#组合两个表

题目描述: 给你一个字符串 columnTitle ,表示 Excel 表格中的列名称。返回 该列名称对应的列序号 。 分析: 法1,进制转换 这道题要求将Excel 表中的列名称转换成相对应的列序号。由于Excel 表的列名称由大写字母组成&#xff…

vue学习53~60(Vue组件化编程)

2 Vue组件化编程 2.1 模块与组件、模块化与组件化 2.1.1 模块 理解:向外提供特定功能的js程序,一般就是一 个js文件为什么: js 文件很多很复杂作用:复用js,简化js的编写,提高js运行效率 2.1.2 组件 理解:用来实现局部(特定)功能效果的代码集合(html/css/js/image…)为什么…

正大国际期货:外盘期货交易中常见的五类技术分析方法

外盘期货交易中,技术分析是必不可少的,技术分析是指以市场行为为研究对象,以判断市场趋势并跟随趋势的周期性变化来进行一切金融衍生物交易决策的方法的总和。常用的技术方法大体上可以分五大类:指标类、切线类、形态类、波浪类、…

安卓程序逆向与防护

安卓程序逆向与防护实际用处代码打包生成apk的步骤程序基础逆向步骤程序基础防御代码混淆针对逆向工具的防御手段ProguardSO文件防止二次打包程序进阶逆向攻击实战练习逆向简易安卓程序实际用处 1.当想要获得一款前后端分离的安卓程序的数据时,一般会考虑抓包后端传…

Kanzi:关于kanzi的一点杂谈

概述: 做过开发的小伙伴在初次接触Kanzi Studio 这个开发工具时,可能有点摸不着头脑,由于 它不像Android studio 也 不像QT ,而且最大的一个区别是:kanzi基本不用写代码逻辑来控制程序显示UI,但是Android …

做外贸一定要知道的20条经验教训

做外贸你必须知道的20课,由米贸搜为你整理如下: 1.在工厂里,客人抱怨价格太高的时候,我总是说一分钱一分货,质量好的回复。进入一家贸易公司后,我知道价格才是硬道理,尤其是大客人。对价格的考虑肯定高于对…

1776年美国才建国,那一年中国在干什么?

时代淘汰你,都不会跟你打一声招呼。时代的残酷性,对人如此,对国家也是这般。美国的历史是太嫩了,在1776年才得以建国。但在这年,美国踏上了工业化革命的节奏,走上了扬帆起航之旅,逐步成为了超级…

JavaIO流处理笔记(万字总结)

学习视频561-JavaSE进阶-IO流概述_哔哩哔哩_bilibili 目录 IO流概述 IO流的分类 IO流四大家族 FileInputStream初步(并非最终方法) FileInputStream循环读(并非最终方法) 往byte数组中读 FileInputStream最终版 FileInputStream的其他常用方法 FileOutputStream的使用…

Kamiya丨Kamiya艾美捷抗冷休克结构域蛋白E1说明书

Kamiya艾美捷抗冷休克结构域蛋白E1化学性质: 物种反应性:人类其他未知物种。 Ig同种型:正常兔全血抗体 免疫原:表达重组CSDE1(Met1~Val245)在大肠杆菌中 格式:500g/mL多克隆抗体在0.01M PBS…

【Redis】List类型和底层原理

文章目录List类型1.List介绍1.1常用命令2.List底层实现3.ziplist剖析3.1ziplist结构3.2创建一个空的ziplist3.3ziplist的元素节点结构3.4ziplisqt的连锁更新3.5ziplist的缺陷4.quicklist剖析4.1quicklist表头结构5.List的应用场景----消息队列5.1保证消息保序5.2处理重复的消息…

Ubuntu搭建本地web站点,并内网穿透实现公网访问

本次教程我们通过搭建Apache服务,部署一个简单的静态样例站点,并使用cpolar内网穿透将内网样例站点发布到公网来进行演示。 1. 设置 Apache Web 服务器 1.1 安装Apache Web sudo apt-get install apache2 -y1.2 启动Apache Web sudo service apache2…

[附源码]计算机毕业设计springboot校园招聘微信小程序

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

[附源码]计算机毕业设计自行车租赁管理系统Springboot程序

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

CSS盒子模型

🍓个人主页:bit.. 🍒系列专栏:Linux(Ubuntu)入门必看 C语言刷题 数据结构与算法 HTML和CSS3 目录 1.盒子模型 1.2盒子模型(Box Model)组成 1.3边框(border) 1.4 表格的…