Python爬虫之公交路线及公交站坐标获取

转载

  1. http://blog.csdn.net/wenwu_both/article/ 
  2. https://zhuanlan.zhihu.com/p/33003655
1.公交路线获取
# coding: utf-8
# @Time    : 2018/5/27
# @Author  : A1058420631
# @FileName: Network_bus.py
# @Software: pycharm

import requests ##导入requests
from bs4 import BeautifulSoup ##导入bs4中的BeautifulSoup
import os

headers =  {'User-Agent':'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.221 Safari/537.36 SE 2.X MetaSr 1.0'}
all_url = 'http://shenyang.8684.cn'  ##开始的URL地址
start_html = requests.get(all_url, headers=headers)
#print (start_html.text)
Soup = BeautifulSoup(start_html.text, 'lxml')
all_a = Soup.find('div',class_='bus_kt_r1').find_all('a')
Network_list = []
for a in all_a:
    href = a['href'] #取出a标签的href 属性
    html = all_url + href
    second_html = requests.get(html,headers=headers)
    #print (second_html.text)
    Soup2 = BeautifulSoup(second_html.text, 'lxml')
    all_a2 = Soup2.find('div',class_='cc_content').find_all('div')[-1].find_all('a') # 既有id又有class的div不知道为啥取不出来,只好迂回取了
    for a2 in all_a2:
        title1 = a2.get_text() #取出a1标签的文本
        href1 = a2['href'] #取出a标签的href 属性
        #print (title1,href1)
        html_bus = all_url + href1
        thrid_html = requests.get(html_bus,headers=headers)
        Soup3 = BeautifulSoup(thrid_html.text, 'lxml')

        bus_name = Soup3.find('div',class_='bus_i_t1').find('h1').get_text()
        # bus_type = Soup3.find('div',class_='bus_i_t1').find('a').get_text()
        # bus_time = Soup3.find_all('p',class_='bus_i_t4')[0].get_text()
        # bus_cost = Soup3.find_all('p',class_='bus_i_t4')[1].get_text()
        # bus_company = Soup3.find_all('p',class_='bus_i_t4')[2].find('a').get_text()
        # bus_update = Soup3.find_all('p',class_='bus_i_t4')[3].get_text()
        # bus_label = Soup3.find('div',class_='bus_label')
        # if bus_label:
        #     bus_length = bus_label.get_text()
        # else:
        #     bus_length = []
        #print (bus_name,bus_type,bus_time,bus_cost,bus_company,bus_update)

        # all_line = Soup3.find_all('div',class_='bus_line_top')
        # all_site = Soup3.find_all('div',class_='bus_line_site')
        # line_x = all_line[0].find('div',class_='bus_line_txt').get_text()[:-9]+all_line[0].find_all('span')[-1].get_text()
        # sites_x = all_site[0].find_all('a')
        # sites_x_list = []
        # for site_x in sites_x:
        #     sites_x_list.append(site_x.get_text())
        # line_num = len(all_line)
        # if line_num==2:  # 如果存在环线,也返回两个list,只是其中一个为空
        #     line_y = all_line[1].find('div',class_='bus_line_txt').get_text()[:-9]+all_line[1].find_all('span')[-1].get_text()
        #     sites_y = all_site[1].find_all('a')
        #     sites_y_list = []
        #     for site_y in sites_y:
        #         sites_y_list.append(site_y.get_text())
        # else:
        #     line_y,sites_y_list=[],[]

        #information = [bus_name,bus_type,bus_time,bus_cost,bus_company,bus_update,bus_length,line_x,sites_x_list,line_y,sites_y_list]
        #information = [line_x,sites_x_list,line_y,sites_y_list]
        information = [bus_name]

        Network_list.append(information)
# 定义保存函数,将运算结果保存为txt文件
def text_save(content,filename,mode='a'):
    # Try to save a list variable in txt file.
    file = open(filename,mode)
    for i in range(len(content)):
        file.write(str(content[i])+'\n')
    file.close()

# 输出处理后的数据
text_save(Network_list,'Network_bus.txt');
Python爬虫之公交路线及公交站坐标获取_第1张图片
2.公交站点坐标获取
# coding: utf-8
# @Time    : 2018/5/27
# @Author  : A1058420631
# @FileName: Location_bus.py
# @Software: pycharm

import requests
import json

network = open('Network_bus.txt', 'r')
location = open('Location_bus.txt', 'a')

line = network.readlines()
for i in line:
    number = str(i[4:7])
    # print(number)
    url = 'https://ditu.amap.com/service/poiInfo?query_type=TQUERY&pagesize=20&pagenum=1&qii=true&cluster_state=5&need_utd=true&utd_sceneid=1000&div=PC1000&addr_poi_merge=true&is_classify=true&zoom=12&city=210100&geoobj=123.346699%7C41.738768%7C123.621357%7C41.859828&keywords=' + number + '%E8%B7%AF'
    json_obj = requests.get(url)
    # print(json_obj.text)

    data = json_obj.json()
    if (data["data"]["message"]) and (data["data"]["busline_list"]):
        buslists = data["data"]["busline_list"]  # busline列表
        buslist = buslists[0]  # 选择方向


    # 公交站点
    def BusStations(buslist):
        busstation = []
        buslinename = buslist["name"]
        busstation.append(buslinename)
        stations = buslist["stations"]
        for station in stations:
            stationname = station["name"]
            stationxy = station["xy_coords"].split(";")
            busstation.append(stationname)
            busstation.append(stationxy)
        return busstation


    busstations = BusStations(buslist)
    location.writelines(str(busstations))
    location.writelines('\n')


你可能感兴趣的:(转载)