Title: Python抓取One网页上的内容
Date: 2016-05-06 16:46
Modified: 2016-05-06 16:46
Category: 脚本
Tags: one,request,beautifulsoup4
Slug: python_one_soup
Authors: lizhonghuan
Summary: 本文是从微信推送内容中摘取下来的,其中某些内容进行了小的改动,本文作者在Mac 10.11.4下运行正常,脚本会存取网页上的内容并保存到本地txt文件中,文件中内容以json格式保存。
1.python环境搭建
安装homebrew
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
安装pip
首先安装easy_install
curl https://bootstrap.pypa.io/ez_setup.py -o - | sudo python
接着
sudo easy_install pip
安装virtualenv
pip install virtualenv
安装request和beautifulsoup4
pip install requests beautifulsoup4
2.网页分析
3.python编码
import argparse
import re
from multiprocessing import Pool
import requests
import bs4
import time
import json
import io
root_url = 'http://wufazhuce.com'
def get_url(num):
return root_url+'/one/'+str(num)
def get_urls(num):
urls = map(get_url,range(100,100+num))
return urls
def get_data(url):
dataList = {}
response = requests.get(url)
if response.status_code != 200:
return {'noValue':'noValue'}
soup = bs4.BeautifulSoup(response.text,'html.parser')
print soup.title.string
dataList['index'] = soup.title.string[4:7]
for meta in soup.select('meta'):
if meta.get('name') == 'description':
dataList['content'] = meta.get('content')
dataList['imgUrl'] = soup.find_all('img')[1]['src']
return dataList
if __name__ == '__main__':
pool = Pool(4)
dataList = []
urls = get_urls(10)
start = time.time()
dataList = pool.map(get_data,urls)
end = time.time()
print 'use:%.2f s'%(end-start)
jsonData = json.dumps({'data':dataList})
with open('data.txt','w') as outfile:
json.dump(jsonData,outfile)