zoukankan      html  css  js  c++  java
  • 4.1 团队作业1(python爬取数据)

    这个作业最初的第一步应该是爬取疫情数据,所以近几天一直在学习python爬取数据

    全靠自学确实有点难,而且python的语法和之前学的C/C++/JAVA的差别有点大啊,但是也算是好理解吧

    不过在这个过程中还是遇到了很多困难和错误。看一下这个爬取数据的python文件吧!

    import pymysql
    import time
    import json
    import traceback  #追踪异常
    import requests
    
    
    
    def get_tencent_data():
        """
        :return: 返回历史数据和当日详细数据
        """
        url = 'https://view.inews.qq.com/g2/getOnsInfo?name=disease_h5'
        url_his = 'https://view.inews.qq.com/g2/getOnsInfo?name=disease_other'  # 加上这个history大兄弟++++++++
    
        headers = {
            'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/65.0.3325.181 Safari/537.36',
        }
        r = requests.get(url, headers)
        res = json.loads(r.text)  # json字符串转字典
        data_all = json.loads(res['data'])
    
        # 再加上history的配套东东++++++++
        r_his = requests.get(url_his, headers)
        res_his = json.loads(r_his.text)
        data_his = json.loads(res_his['data'])
    
        history = {}  # 历史数据
    
        for i in data_his["chinaDayList"]:
            ds = "2021." + i["date"]
            tup = time.strptime(ds, "%Y.%m.%d")
            ds = time.strftime("%Y-%m-%d", tup)  # 改变时间格式,不然插入数据库会报错,数据库是datetime类型
            confirm = i["confirm"]
            suspect = i["suspect"]
            heal = i["heal"]
            dead = i["dead"]
            history[ds] = {"confirm": confirm, "suspect": suspect, "heal": heal, "dead": dead}
        for i in data_his["chinaDayAddList"]:
            ds = "2021." + i["date"]
            tup = time.strptime(ds, "%Y.%m.%d")
            ds = time.strftime("%Y-%m-%d", tup)
            confirm = i["confirm"]
            suspect = i["suspect"]
            heal = i["heal"]
            dead = i["dead"]
            history[ds].update({"confirm_add": confirm, "suspect_add": suspect, "heal_add": heal, "dead_add": dead})
    
        # 下面就不用动了
        details = []  # 当日详细数据
        update_time = data_all["lastUpdateTime"]
        data_country = data_all["areaTree"]  # list 25个国家
        data_province = data_country[0]["children"]  # 中国各省
        for pro_infos in data_province:
            province = pro_infos["name"]  # 省名
            for city_infos in pro_infos["children"]:
                city = city_infos["name"]
                confirm = city_infos["total"]["confirm"]
                confirm_add = city_infos["today"]["confirm"]
                heal = city_infos["total"]["heal"]
                dead = city_infos["total"]["dead"]
                details.append([update_time, province, city, confirm, confirm_add, heal, dead])
        return history, details
    
    
    def get_conn():
        """
        :return: 连接,游标
        """
        # 创建连接
        conn = pymysql.connect(host="localhost",
                               user="root",
                               password="root1",
                               db="cov",
                               charset="utf8")
        # 创建游标
        cursor = conn.cursor()  # 执行完毕返回的结果集默认以元组显示
        return conn, cursor
    
    
    def close_conn(conn, cursor):
        if cursor:
            cursor.close()
        if conn:
            conn.close()
    
    
    def update_details():
        """
        更新 details 表
        :return:
        """
        cursor = None
        conn = None
        try:
            li = get_tencent_data()[1]  #  0 是历史数据字典,1 最新详细数据列表
            conn, cursor = get_conn()
            sql = "insert into details(update_time,province,city,confirm,confirm_add,heal,dead) values(%s,%s,%s,%s,%s,%s,%s)"
            sql_query = 'select %s=(select update_time from details order by id desc limit 1)' #对比当前最大时间戳
            cursor.execute(sql_query,li[0][0])
            if not cursor.fetchone()[0]:
                print(f"{time.asctime()}开始更新最新数据")
                for item in li:
                    cursor.execute(sql, item)
                conn.commit()  # 提交事务 update delete insert操作
                print(f"{time.asctime()}更新最新数据完毕")
            else:
                print(f"{time.asctime()}已是最新数据!")
        except:
            traceback.print_exc()
        finally:
            close_conn(conn, cursor)
    
    
    def insert_history():
        """
            插入历史数据
        :return:
        """
        cursor = None
        conn = None
        try:
            dic = get_tencent_data()[0]  # 0 是历史数据字典,1 最新详细数据列表
            print(f"{time.asctime()}开始插入历史数据")
            conn, cursor = get_conn()
            sql = "insert into history values(%s,%s,%s,%s,%s,%s,%s,%s,%s)"
            for k, v in dic.items():
                # item 格式 {'2020-01-13': {'confirm': 41, 'suspect': 0, 'heal': 0, 'dead': 1}
                cursor.execute(sql, [k, v.get("confirm"), v.get("confirm_add"), v.get("suspect"),
                                        v.get("suspect_add"), v.get("heal"), v.get("heal_add"),
                                        v.get("dead"), v.get("dead_add")])
    
            conn.commit()  # 提交事务 update delete insert操作
            print(f"{time.asctime()}插入历史数据完毕")
        except:
            traceback.print_exc()
        finally:
            close_conn(conn, cursor)
    
    
    def update_history():
        """
        更新历史数据
        :return:
        """
        cursor = None
        conn = None
        try:
            dic = get_tencent_data()[0]  #  0 是历史数据字典,1 最新详细数据列表
            print(f"{time.asctime()}开始更新历史数据")
            conn, cursor = get_conn()
            sql = "insert into history values(%s,%s,%s,%s,%s,%s,%s,%s,%s)"
            sql_query = "select confirm from history where ds=%s"
            for k, v in dic.items():
                # item 格式 {'2020-01-13': {'confirm': 41, 'suspect': 0, 'heal': 0, 'dead': 1}
                if not cursor.execute(sql_query, k):
                    cursor.execute(sql, [k, v.get("confirm"), v.get("confirm_add"), v.get("suspect"),
                                         v.get("suspect_add"), v.get("heal"), v.get("heal_add"),
                                         v.get("dead"), v.get("dead_add")])
            conn.commit()  # 提交事务 update delete insert操作
            print(f"{time.asctime()}历史数据更新完毕")
        except:
            traceback.print_exc()
        finally:
            close_conn(conn, cursor)
    
    
    if __name__ == "__main__":
        #  insert_history()
        update_history()
        update_details()
  • 相关阅读:
    高级人力资源管理最喜欢的工具;笔迹分析测试的六大好处
    我与时尚MM的那些事儿
    当幸福来敲门
    perl 模板
    一些R函数【自己使用过,保存】
    关于异步加载、缓存图片、软引用等
    android线程同步
    现半透明的popupwindow
    android中的MotionEvent 及其它事件处理
    android客户端从服务器端获取json数据并解析
  • 原文地址:https://www.cnblogs.com/cdl-sunshine/p/14907686.html
Copyright © 2011-2022 走看看