2021-02-22 文件操作作业二,用户输入城市,获取这个城市的天气

文件操作作业二,用户输入城市,获取这个城市的天气

## 作业


'''
2、用户输入城市,获取这个城市的天气
'''

import os
import requests
from xml.etree import  ElementTree as ET
from openpyxl import workbook

# 文件路径处理
base_dir = os.path.dirname(os.path.abspath(__file__))
db_file_path = os.path.join(base_dir,'weather.xlsx')

# 创建一个新的excel文件
wb = workbook.Workbook()
del wb['Sheet']

while True:
    # 用户输入城市
    city = input('输入想要查询的城市:')
    if city.upper() == 'Q':
        break

    url = 'http://ws.webxml.com.cn/WebServices/WeatherWebService.asmx/getWeatherbyCityName={}'.format(city)
    #url2 = 'http://ws.webxml.com.cn/WebServices/WeatherWS.asmx/getWeather?theCityCode={}&theUserID={} HTTP/1.1'.format(city,2013)
    res = requests.get(url=url)
    print(res.text)


    # 1、提取XML格式的数据
    root = ET.XML(res.text)

    # 2、为每个城市创建一个sheet,并把获取到的xml写入到excel中
    sheet = wb.create_sheet(city)

    for row_index,node in enumerate(root,1):
        text = node.text
        cell = sheet.cell(row_index,1)
        cell.value = text

# wb.save(target_excel_file_path)


## 求助程序运行后,url请求获取到的内容为  “getWeatherbyCityName=上海 Web 服务方法名无效。”
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值