爬虫03_股票数据定向爬虫

1.准备工作

功能描述:
目标:获取上交所和深交所所有股票的名称和交易信息
输出:保存到文件中
所用技术:requests、bs4、re、csv

数据网站选择
新浪股票:http://finance.sina.com.cn/stock/ (动态)
网易股票:http://quotes.money.163.com/ (静态)
凤凰财经:http://app.finance.ifeng.com/list/stock.php (静态)
原则:选择将股票数据静态写在html页面中的,而不是用js动态生成的,同时确保robots协议限制
选取方法:浏览器F12,源代码查看等,不要纠结于某个网站,多找信息源尝试。

程序的结构设计
1.从凤凰财经网获取源代码
2.获取个股信息
3.将结果存储到文件

2.代码实现

import requests
import re
from bs4 import BeautifulSoup
import csv

def getHTMLText(url):
    try:
        r = requests.get(url,)
        r.raise_for_status()
        r.encoding = r.apparent_encoding
        return r.text
    except:
        print("爬取失败")
        return ""


def getStockInfo(html,stock_info,):
    try:
        if html=="":
           pass
        soup = BeautifulSoup(html,'html.parser')

        for tr in soup.find('table').children:
            if isinstance(tr, bs4.element.Tag):
                tds = tr('td')

                if tds == []:
                    continue
                elif re.findall(r'colspan="11"',str(tds)):
                    continue
                else:
                    stock_info.append([tds[0].string,tds[1].string,tds[2].string])

        return stock_info
    except:
        print("出现异常")

def createFile(stock_info,file_path):
    title = ["代码","名字","现价"]
    with open(file_path,'w',encoding="utf8") as f:
        writer = csv.writer(f)
        writer.writerow(title)
        for i in range(len(stock_info)):
            writer.writerow(stock_info[i])
    print("success!")
if __name__ == '__main__':
    base_url = "http://app.finance.ifeng.com/list/stock.php?"
    page =2
    file_path = "D://pachong/StockInfo.csv"
    stock_info = []
    for i in range(page):
        url = base_url + '&p=' +str(i+1)
        html = getHTMLText(url)
        getStockInfo(html,stock_info)
    createFile(stock_info,file_path)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值