from asyncio.exceptions import TimeoutError import nonebot import ujson as json from nonebot.drivers import Driver from nonebot_plugin_apscheduler import scheduler from zhenxun.configs.path_config import TEXT_PATH from zhenxun.services.log import logger from zhenxun.utils.http_utils import AsyncHttpx driver: Driver = nonebot.get_driver() @driver.on_startup async def update_city(): """ 部分插件需要中国省份城市 这里直接更新,避免插件内代码重复 """ china_city = TEXT_PATH / "china_city.json" data = {} if not china_city.exists(): try: logger.debug("开始更新城市列表...") res = await AsyncHttpx.get( "http://www.weather.com.cn/data/city3jdata/china.html", timeout=5 ) res.encoding = "utf8" provinces_data = json.loads(res.text) for province in provinces_data.keys(): data[provinces_data[province]] = [] res = await AsyncHttpx.get( f"http://www.weather.com.cn/data/city3jdata/provshi/{province}.html", timeout=5, ) res.encoding = "utf8" city_data = json.loads(res.text) for city in city_data.keys(): data[provinces_data[province]].append(city_data[city]) with open(china_city, "w", encoding="utf8") as f: json.dump(data, f, indent=4, ensure_ascii=False) logger.info("自动更新城市列表完成...") except TimeoutError as e: logger.warning("自动更新城市列表超时...", e=e) except ValueError as e: logger.warning("自动城市列表失败...", e=e) except Exception as e: logger.error(f"自动城市列表未知错误...", e=e) # 自动更新城市列表 @scheduler.scheduled_job( "cron", hour=6, minute=1, ) async def _(): await update_city()