使用python抓取有路网图书信息(原创)
以前挺喜欢去有路网买二手书的,但是有路网有个缺陷,就是放在图书列表中的书很多都没货了,尤其是一些热门的方向,比如android,在列表中的书大多都没有货了,你必须一个一个点进入查看详细信息才能得知图书是否有货。因此,很久之前用python写了一个抓取的脚本,用来按书名搜索图书以及库存信息。现在拿出来与大家分享一下,因为是最开始学python的时候写的,有些地方写的不是特别好。比如那个时候对于正则表达式不是特别懂,所以用的不是特别好。其次,采用urllib库发送http请求的,效率太低。建议使用tornado库或者采用node.js(见 http://www.cnblogs.com/dyf6372/p/3536821.html)。哦,还有一个问题,网页编码处理的不好,可能部分网页会乱码。废话少说,直接上代码:
# coding: utf-8
import urllib
import re
import sys
reload(sys)
sys.setdefaultencoding('utf8')
class ReadFromWeb:
      def setKeyWord(self, keyword):
            self.url = 'http://www.youlu.net/search/result/?isbn=&publisherName=&author=&bookName=' + urllib.quote(keyword.decode('utf-8').encode('gb18030'))
  def getHtml(self):
            try:
                  self.html = urllib.urlopen(self.url).read().decode('gb18030').encode('utf-8')
            except UnicodeDecodeError:
                  self.html = urllib.urlopen(self.url).read()
            finally:
                  return self.html
  def list(self):
            self.id_group = re.findall('<a href=\"/[0-9]*\" target=\"_blank\">.*</a>', self.html)
            for in_id in self.id_group:
                  try:
                        url = re.findall('[0-9]+',in_id)[0].encode('utf-8')
                        detail = re.findall('>.*<',in_id)[0].encode('utf-8')
                  except UnicodeDecodeError:
                        url = re.findall('[0-9]+',in_id)[0]
                        detail = re.findall('>.*<',in_id)[0]
      if detail.find('img')<0 and detail.find('我要购买')<0:
                        if self.getDetail(url) > 0:
                              print detail[1:-1]
                              print '有货:'+str(self.getDetail(url))+":"+"http://www.youlu.net/"+url
                        else:
                              print detail[1:-1]
                              print '无货'+":"+"http://www.youlu.net/"+url
  def getDetail(self, url):
            target = "http://www.youlu.net/" + str(url);
            try:
                  returnStr = urllib.urlopen(target).read().decode('gb18030').encode('utf-8')
            except UnicodeDecodeError:
                  return 0
            startStr = re.findall('startRequestBookBuyLink\(.*\)',returnStr)[0]
            realNumber = int(startStr.split(',')[3].strip()[1:-1])
            return realNumber
  def setSearchNextPage(self):
            self.nextPage = re.findall('(?<=\"下一页\" href=\").*(?=\">下一页</a>)', self.html)
            if len(self.nextPage) > 0:
                  self.url = self.nextPage[0]
                  return True
            return False
  def setAndSearch(self,keyword):
            self.setKeyWord(keyword)
            self.getHtml()
            self.list()
            while self.setSearchNextPage():
                  self.getHtml()
                  self.list()
if __name__ == "__main__":
      keyword = raw_input("Type in search keyword:")
      readFromWeb = ReadFromWeb()
      readFromWeb.setAndSearch(keyword)
下面是使用结果示例:
————————————————————————————
Type in search keyword:java
JAVA 2实用教程实验指导与习题解答-(第三版)
有货:190:http://www.youlu.net/2597032
Java面向对象程序设计
有货:88:http://www.youlu.net/2504849
Java EE 5开发基础与实践
有货:70:http://www.youlu.net/500752
Java 2实用教程 (第三版)
有货:68:http://www.youlu.net/5310
Java课程设计(第二版)
有货:61:http://www.youlu.net/500751
JAVA 2实用教程实验指导与习题解答-(第三版)
有货:60:http://www.youlu.net/2596529
JAVA 2实用教程(第三版)-实验指导与习题解答
有货:48:http://www.youlu.net/10750
Java 语言与面向对象程序设计(第2版)
有货:47:http://www.youlu.net/356506
Java程序设计教程(第2版)
有货:42:http://www.youlu.net/1008395
Java XML应用程序设计
有货:39:http://www.youlu.net/338105
Java程序设计习题集(含参考答案)
有货:37:http://www.youlu.net/1206253
Java大学实用教程学习指导(第2版)
有货:37:http://www.youlu.net/461648
使用python抓取有路网图书信息(原创)的更多相关文章
- 使用node.js抓取有路网图书信息(原创)
		
之前写过使用python抓取有路网图书信息,见http://www.cnblogs.com/dyf6372/p/3529703.html. 最近想学习一下Node.js,所以想试试手,比较一下http ...
 - Python 抓取网页并提取信息(程序详解)
		
最近因项目需要用到python处理网页,因此学习相关知识.下面程序使用python抓取网页并提取信息,具体内容如下: #---------------------------------------- ...
 - 用python抓取智联招聘信息并存入excel
		
用python抓取智联招聘信息并存入excel tags:python 智联招聘导出excel 引言:前一阵子是人们俗称的金三银四,跳槽的小朋友很多,我觉得每个人都应该给自己做一下规划,根据自己的进步 ...
 - 使用python抓取58手机维修信息
		
之前在ququ的博客上看到说 python 中的BeautifulSoup 挺好玩的,今天下午果断下载下来,看了下api,挺好用的,完了2把,不错. 晚上写了一个使用python抓取58手机维修信息的 ...
 - python抓取链家房源信息(二)
		
试着用scrapy将之前写的抓取链家网信息的重新写了写 然后先是用了第一页的网页作为测试,调试代码,然后发现总是抓取的时候遇见了 类似于这样的问题,并且抓取不到信息 2017-03-28 17:52: ...
 - python抓取链家房源信息(三)
		
之前写过一个链家网北京二手房的数据抓取,然后本来今天想着要把所有的东西弄完,但是临时有事出去了一趟,耽搁了一下,然后现在是想着把北京的二手房的信息都进行抓取,并且存储在mongodb中, 首先是通过' ...
 - python抓取链家房源信息
		
闲着没事就抓取了下链家网的房源信息,抓取的是北京二手房的信息情况,然后通过网址进行分析,有100页,并且每页的url都是类似的 url = 'https://bj.lianjia.com/ershou ...
 - 我的第一个爬虫程序:利用Python抓取网页上的信息
		
题外话 我第一次听说Python是在大二的时候,那个时候C语言都没有学好,于是就没有心思学其他的编程语言.现在,我的毕业设计要用到爬虫技术,在网上搜索了一下,Python语言在爬虫技术这方面获得一致好 ...
 - 简单的抓取淘宝关键字信息、图片的Python爬虫|Python3中级玩家:淘宝天猫商品搜索爬虫自动化工具(第一篇)
		
Python3中级玩家:淘宝天猫商品搜索爬虫自动化工具(第一篇) 淘宝改字段,Bugfix,查看https://github.com/hunterhug/taobaoscrapy.git 由于Gith ...
 
随机推荐
- C# 网络编程之豆瓣OAuth2.0认证具体解释和遇到的各种问题及解决
			
近期在帮人弄一个豆瓣API应用,在豆瓣的OAuth2.0认证过程中遇到了各种问题,同一时候自己须要一个个的尝试与解决,终于完毕了豆瓣API的訪问.作者这里就不再吐槽豆瓣的认证文档了,毕 ...
 - sql根据表名获取字段及对应说明
			
SELECT TableName = OBJECT_NAME(c.object_id), ColumnsName = c.name, Description = ex.value, ColumnTyp ...
 - iOS的崩溃和编译错误
			
1. Command /bin/sh failed with exit code 127 这是因为mogenerator找不到路径,stackoverflow给出的答案是: If /usr/local ...
 - 写实例学习html5 WebSocket
			
WebSocket简介 WebSocket是html5的重要特性.它是HTML5一种新的协议,实现了浏览器与服务器全双工通信(full-duplex).使服务器可以主动传送数据给客户端,对构建实时w ...
 - 转:Internal Sales Order (ISO) Process Flow
			
本文介绍下内部销售订单Internal Sales Order(ISO)在Oracle EBS中的流程,内部销售订单和组织间转移(Inter-Organization Transfer,IOT)的作用 ...
 - mapping 详解2(field datatypes)
			
基本类型 1. 字符串 字符串类型被分为两种情况:full-text 和 keywords. full-text 表示字段内容会被分析,而 keywords 表示字段值只能作为一个精确值查询. 参数: ...
 - 让ubuntu开启ssh服务以及让vi/vim正常使用方向键与退格键
			
VIM 修复方法: 安装vim full版本,在full版本下键盘正常,安装好后同样使用vi命令.ubuntu预装的是vim tiny版本,而需要的是vim full版本.执行下面的语句安装vim f ...
 - css动画——transition和animation
			
http://www.ruanyifeng.com/blog/2014/02/css_transition_and_animation.html 第一部分:CSS Transition 在CSS 3引 ...
 - 关于增强for循环
			
1 增强for循环增强for循环是for的一种新用法!用来循环遍历数组和集合. 1.1 增强for的语法for(元素类型 e : 数组或集合对象) {}例如:int[] arr = {1,2,3};f ...
 - 关于XML的DTD概述
			
1 DTD概述 1.1 什么是DTD DTD(Document Type Definition),文档类型定义,用来约束XML文档.或者可以把DTD理解为创建XML文档的结构!例如可以用DTD要求XM ...