天天看點

python爬取:爬蟲 -- 某天基金網資料簡單爬取

本文的文字及圖檔來源于網絡,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯系我們以作處理

本品文章來自騰訊雲 作者:孤獨的明月

python爬取:爬蟲 -- 某天基金網資料簡單爬取

目标 — 簡單擷取天天基金網站的基金資料

代碼區

import requestsimport timeimport pandas as pdif __name__ == '__main__':for j in range(1, 49):
        url = f'http://fund.eastmoney.com/Data/Fund_JJJZ_Data.aspx?t=1&lx=1&letter=&gsid=&text=&sort=zdf,desc&page={j},200&dt=1597126258333&atfc=&onlySale=0'headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.1 (KHTML, like Gecko) Chrome/21.0.1180.71 Safari/537.1 LBBROWSER'}
        resp = requests.get(url, headers=headers).text
        str_ = resp[102:]
        list1 = eval(str_.split(",count")[0])print(f'正在爬取第{j}頁')print(f'本頁爬取{len(list1)}條資料')
    
        num = []
        name = []
        today_price = []
        yesterday_price = []
        day_value = []
        day_value_rate = []
        subscription_status = []
        redemption_status = []
        service_charge = []for i in range(len(list1)):          # 1、基金代碼号            num.append(list1[i][0])# 2、股票名稱name.append(list1[i][1])      # 3、今日基金淨額today_price.append(list1[i][3])# 4、昨日基金淨額yesterday_price.append(list1[i][5])# 5、日增長值day_value.append(list1[i][7])# 6、日增長率day_value_rate.append(list1[i][8])# 7、申購狀态subscription_status.append(list1[i][9])# 8、贖回狀态redemption_status.append(list1[i][10])# 9、手續費service_charge.append(list1[i][17])

        df = pd.DataFrame()
        df['基金代碼'] = num
        df['基金名稱'] = name
        df['2020-08-12\n機關淨值'] = today_price
        df['2020-08-11\n機關淨值'] = yesterday_price
        df['日增長值'] = day_value
        df['日增長率\n%'] = day_value_rate
        df['申購狀态'] = subscription_status
        df['贖回狀态'] = redemption_status
        df['手續費'] = service_chargetry:
            df.to_excel(f'基金{j}.xlsx', '基金資訊', index=None, encoding='utf-8')except Exception as e:print(e)

    time.sleep(1)      

效果