全新正版书籍,24小时发货,可开发票。
¥ 37.5 7.7折 ¥ 49 全新
库存5件
作者罗刚
出版社清华大学出版社
ISBN9787302442646
出版时间2016-09
装帧平装
开本16开
定价49元
货号24028153
上书时间2024-12-24
罗刚,计算机软件硕士,毕业于吉林工业大学。2005年创立北京盈智星科技发展有限公司,2008年联合创立上海数聚软件公司。猎兔搜索创始人,当前猎兔搜索在北京、上海以及石家庄均设有研发部。他带领猎兔搜索技术开发团队先后开发出猎兔中文分词系统、猎兔文本挖掘系统,智能垂直搜索系统以及网络信息监测系统等,实现互联网信息的采集、过滤、搜索和实时监测,其开发的搜索软件日用户访问量万次以上。
第1篇 自己动手抓取数据 第1章 全面剖析网络爬虫 3 1.1 抓取网页 4 1.1.1 深入理解URL 4 1.1.2 通过指定的URL抓取 网页内容 6 1.1.3 Java网页抓取示例 8 1.1.4 处理HTTP状态码 10 1.2 宽度优先爬虫和带偏好的爬虫 12 1.2.1 图的宽度优先遍历 12 1.2.2 宽度优先遍历互联网 13 1.2.3 Java宽度优先爬虫示例 15 1.2.4 带偏好的爬虫 22 1.2.5 Java带偏好的爬虫示例 23 1.3 设计爬虫队列 24 1.3.1 爬虫队列 24 1.3.2 使用Berkeley DB构建爬虫 队列 29 1.3.3 使用Berkeley DB 构建爬虫 队列示例 30 1.3.4 使用布隆过滤器构建 Visited表 36 1.3.5 详解Heritrix爬虫队列 39 1.4 设计爬虫架构 46 1.4.1 爬虫架构 46 1.4.2 设计并行爬虫架构 47 1.4.3 详解Heritrix爬虫架构 52 1.5 使用多线程技术提升爬虫性能 55 1.5.1 详解Java多线程 55 1.5.2 爬虫中的多线程 59 1.5.3 一个简单的多线程爬虫实现 60 1.5.4 详解Heritrix多线程结构 61 本章小结 64 第2章 分布式爬虫 69 2.1 设计分布式爬虫 70 2.1.1 分布式与云计算 70 2.1.2 分布式与云计算技术在 爬虫中的应用--浅析 Google的云计算架构 72 2.2 分布式存储 72 2.2.1 从Ralation_DB到key/value 存储 72 2.2.2 Consistent Hash算法 74 2.2.3 Consistent Hash代码实现 79 2.3 Google的成功之道--GFS 80 2.3.1 GFS详解 80 2.3.2 开源GFS--HDFS 84 2.4 Google网页存储秘诀--BigTable 88 2.4.1 详解BigTable 88 2.4.2 开源BigTable-HBase 93 2.5 Google的成功之道-- MapReduce算法 98 2.5.1 详解MapReduce算法 100 2.5.2 MapReduce容错处理 101 2.5.3 MapReduce实现架构 102 2.5.4 Hadoop中的MapReduce 简介 104 2.5.5 wordCount例子的实现 105 2.6 Nutch中的分布式 109 2.6.1 Nutch爬虫详解 109 2.6.2 Nutch中的分布式 116 本章小结 118 第3章 爬虫的"方方面面" 121 3.1 爬虫中的"黑洞" 122 3.2 主题爬虫和限定爬虫 122 3.2.1 理解主题爬虫 122 3.2.2 Java主题爬虫 128 3.2.3 理解限定爬虫 130 3.2.4 Java限定爬虫示例 136 3.3 有"道德"的爬虫 152 本章小结 156 第2篇 自己动手抽取Web内容 第4章 "处理"HTML页面 159 4.1 征服正则表达式 160 4.1.1 学习正则表达式 160 4.1.2 Java正则表达式 163 4.2 抽取HTML正文 169 4.2.1 了解Jsoup 169 4.2.2 使用正则表达式抽取示例 173 4.3 抽取正文 177 4.4 从JavaScript中抽取信息 193 4.4.1 JavaScript抽取方法 193 4.4.2 JavaScript抽取示例 195 本章小结 197 第5章 非HTML正文抽取 199 5.1 抽取PDF文件 200 5.1.1 学习PDFBox 200 5.1.2 使用PDFBox抽取示例 204 5.1.3 提取PDF文件标题 205 5.1.4 处理PDF格式的公文 206 5.2 抽取Office文档 211 5.2.1 学习POI 211 5.2.2 使用POI抽取Word示例 211 5.2.3 使用POI抽取PPT 示例 213 5.2.4 使用POI抽取Excel示例 214 5.3 抽取RTF 217 5.3.1 开源RTF文件解析器 217 5.3.2 实现一个RTF文件解析器 217 5.3.3 解析RTF示例 222 本章小结 227 第6章 多媒体抽取 229 6.1 视频抽取 230 6.1.1 抽取视频关键帧 230 6.1.2 Java视频处理框架 231 6.1.3 Java视频抽取示例 235 6.2 音频抽取 247 6.2.1 抽取音频 248 6.2.2 Java音频抽取技术 252 本章小结 254 第7章 去掉网页中的"噪声" 255 7.1 "噪声"对网页的影响 256 7.2 利用"统计学"消除"噪声" 257 7.2.1 网站风格树 260 7.2.2 "统计学去噪"的 Java实现 268 7.3 利用"视觉"消除"噪声" 272 7.3.1 "视觉"与"噪声" 272 7.3.2 "视觉去噪"的Java实现 273 本章小结 277 第3篇 自己动手挖掘Web数据 第8章 分析Web图 281 8.1 存储Web"图" 282 8.2 利用Web"图"分析链接 291 8.3 Google的秘密--PageRank 291 8.3.1 深入理解PageRank算法 291 8.3.2 PageRank算法的Java实现 295 8.3.3 应用PageRank进行链接 分析 298 8.4 PageRank 的兄弟HITS 299 8.4.1 深入理解HITS算法 299 8.4.2 HITS算法的Java实现 300 8.4.3 应用HITS进行链接分析 311 8.5 PageRank与HITS比较 312 本章小结 313 第9章 去掉"重复"的文档 315 9.1 何为"重复"的文档 316 9.2 利用"语义指纹"排重 316 9.2.1 理解"语义指纹" 318 9.2.2 "语义指纹"排重的 Java实现 319 9.3 SimHash排重 319 9.3.1 理解SimHash 320 9.3.2 SimHash排重的Java实现 321 9.4 分布式文档排重 328 本章小结 329 第10章 分类与聚类的应用 331 10.1 网页分类 332 10.1.1 收集语料库 332 10.1.2 选取网页的"特征" 333 10.1.3 使用支持向量机进行 网页分类 336 10.1.4 利用URL地址进行 网页分类 338 10.1.5 使用AdaBoost进行 网页分类 338 10.2 网页聚类 341 10.2.1 深入理解DBScan算法 341 10.2.2 使用DBScan算法聚类 实例 342 本章小结 344 |
罗刚,计算机软件硕士,毕业于吉林工业大学。2005年创立北京盈智星科技发展有限公司,2008年联合创立上海数聚软件公司。猎兔搜索创始人,当前猎兔搜索在北京、上海以及石家庄均设有研发部。他带领猎兔搜索技术开发团队先后开发出猎兔中文分词系统、猎兔文本挖掘系统,智能垂直搜索系统以及网络信息监测系统等,实现互联网信息的采集、过滤、搜索和实时监测,其开发的搜索软件日用户访问量万次以上。
第2章 分布式爬虫
随着互联网技术的发展以及风起云涌的云计算浪潮,爬虫技术也逐渐向分布式方向发展。比如,Google的爬虫就是使用成千上万台小型机和微机进行合作,完成分布式抓取工作的。分布式技术不仅可以解决IT运营的成本,还可以解决爬虫效率问题,尤其是当今云计算的热潮,更把分布式推向了极致。
2.1 设计分布式爬虫
把抓取任务分布到不同的节点主要是为了抓取性能与可扩展性,也可以使用物理分布的爬虫系统,让每个爬虫节点抓取靠近它的网站。例如,北京的爬虫节点抓取北京的网站,上海的爬虫节点抓取上海的网站,电信网络中的爬虫节点抓取托管在电信的网站,联通网络中的爬虫节点抓取托管在联通的网站。
此外,还需要考虑容错。如果一个节点X崩溃(或优雅地离开),我们可以通过查找任务缓存,知道分配给它哪些任务。这次X的任务要由其他的节点来重新执行。
2.1.1 分布式与云计算
分布式技术是一种基于网络的计算机处理技术,与集中式相对应。近些年来,由于个人计算机的性能得到极大的提高及其使用的普及,使得将处理任务分布到网络上的所有计算机成为可能。分布式计算是和集中式计算相对立的概念,分布式计算的数据可以分布在很大区域去完成。
在分布式网络中,数据的存储和处理都是在本地工作站进行的。数据输出可以打印,也可以保存在软盘上。通过网络能够更快、更便捷地访问数据。因为每台计算机都能够存储和处理数据,所以不要求服务器的功能十分强大,其价格也就不必过于昂贵。这种类型的网络可以适应用户的各种需要,同时允许他们共享网络的数据、资源和服务。在分布式网络中使用的计算机既能够作为独立的系统使用,也可以把它们连接在一起获得更强大的网络功能。
分布式计算的优点是可以快速访问、多用户使用。每台计算机可以访问系统内其他计算机的信息文件,系统设计上具有更大的灵活性。既可为独立计算机的地区用户的特殊需求服务,也可为联网的企业需求服务,实现系统内不同计算机之间的通信,每台计算机都可以拥有和保持所需要的数据和文件,减少了数据传输的成本和风险。为分散地区和中心办公室双方提供更迅速的信息通信和处理方式,为每个分散的数据库提供作用域,数据存储于许多存储单元中,但任何用户都可以进行全局访问,使故障的不利影响小化,以较低的成本来满足企业的特定要求。
云计算(Cloud Computing)是分布式处理(DistributedComputing)、并行处理(Parallel Computing)和网格计算(Grid Computing)的发展,或者说是这些计算机科学概念的商业实现。
云计算的基本原理是,通过使计算任务分布在大量的分布式计算机上,而非本地计算机或远程服务器中,企业数据中心的运行将与互联网更相似。这使得企业能够将资源切换到需要的应用上,从而根据需求访问计算机和存储系统。
这可是一种革命性的举措,打个比方,就好比是从古老的单台发电机模式转向了电厂集中供电的模式。它意味着计算能力也可以作为一种商品进行流通,就像煤气、水电一样,使用方便,费用低廉。的不同在于,它是通过互联网进行传输的。
云计算的蓝图已经呼之欲出:在未来,只需要一台笔记本或者一个手机,就可以通过网络服务来实现我们需要的一切,甚至包括超级计算这样的任务。从这个角度而言,终用户才是云计算的真正拥有者。
云计算的应用包含这样一种思想,把力量联合起来,给其中的每一个成员使用。
目前,PC依然是我们日常工作生活中的核心工具--我们用PC处理文档、存储资料,用电子邮件或U盘与他人分享信息。如果PC硬盘坏了,我们会因为资料丢失而束手无策。
而在云计算时代,"云"会替我们做存储和计算的工作。"云"就是计算机群,每一群都包括几十万台,甚至上百万台计算机。"云"的好处还在于,其中的计算机可以随时更新,保证"云"长生不老。Google就有好几个这样的"云",其他IT巨头,如微软、雅虎、亚马逊(Amazon)也有或正在建设这样的"云"。
届时,我们只需要一台能上网的电脑,不需关心存储或计算发生在哪朵"云"上,一旦有需要,我们可以在任何地点用任何设备,如电脑、手机等,快速地计算和找到这些资料。我们再也不用担心资料会丢失了。
云计算是虚拟化(Virtualization)、效用计算(UtilityComputing)、IaaS(基础设施即服务)、PaaS(
— 没有更多了 —
以下为对购买帮助不大的评价