点击获取提取码:jzgv

内容简介

本书采用基于项目的方法,介绍用Python完成数据获取、数据清洗、数据探索、数据呈现、数据规模化和自动化的过程。主要内容包括:Python基础知识,如何从CSV、Excel、XML、JSON和PDF文件中提取数据,如何获取与存储数据,各种数据清洗与分析技术,数据可视化方法,如何从网站和API中提取数据。

目录

第1章 Python 简介  1

1.1 为什么选择Python  4

1.2 开始使用Python  4

1.2.1 Python 版本选择  5

1.2.2 安装Python  6

1.2.3 测试Python  9

1.2.4 安装pip  11

1.2.5 安装代码编辑器  12

1.2.6 安装IPython(可选)  13

1.3 小结  13

第2章 Python 基础  14

2.1 基本数据类型  15

2.1.1 字符串  15

2.1.2 整数和浮点数  15

2.2 数据容器  18

2.2.1 变量  18

2.2.2 列表  21

2.2.3 字典  22

2.3 各种数据类型的用途  23

2.3.1 字符串方法:字符串能做什么  24

2.3.2 数值方法:数字能做什么  25

2.3.3 列表方法:列表能做什么  26

2.3.4 字典方法:字典能做什么  27

2.4 有用的工具:type、dir 和help  28

2.4.1 type  28

2.4.2 dir  28

2.4.3 help  30

2.5 综合运用  31

2.6 代码的含义  32

2.7 小结  33

第3章 供机器读取的数据  34

3.1 CSV 数据  35

3.1.1 如何导入CSV 数据  36

3.1.2 将代码保存到文件中并在命令行中运行  39

3.2 JSON 数据  41

3.3 XML 数据  44

3.4 小结  56

第4章 处理Excel 文件  58

4.1 安装Python 包  58

4.2 解析Excel 文件  59

4.3 开始解析  60

4.4 小结  71

第5章 处理PDF 文件,以及用Python 解决问题  73

5.1 尽量不要用PDF  73

5.2 解析PDF 的编程方法  74

5.2.1 利用slate 库打开并读取PDF  75

5.2.2 将PDF 转换成文本  77

5.3 利用pdfminer 解析PDF  78

5.4 学习解决问题的方法  92

5.4.1 练习:使用表格提取,换用另一个库  94

5.4.2 练习:手动清洗数据  98

5.4.3 练习:试用另一种工具  98

5.5 不常见的文件类型  101

5.6 小结  101

第6章 数据获取与存储  103

6.1 并非所有数据生而平等  103

6.2 真实性核查  104

6.3 数据可读性、数据清洁度和数据寿命  105

6.4 寻找数据  105

6.4.1 打电话  105

6.4.2 美国政府数据  106

6.4.3 全球政府和城市开放数据  107

6.4.4 组织数据和非政府组织数据  109

6.4.5 教育数据和大学数据  109

6.4.6 医学数据和科学数据  109

6.4.7 众包数据和API  110

6.5 案例研究:数据调查实例  111

6.5.1 埃博拉病毒危机  111

6.5.2 列车安全  111

6.5.3 足球运动员的薪水  112

6.5.4 童工  112

6.6 数据存储  113

6.7 数据库简介  113

6.7.1 关系型数据库:MySQL 和PostgreSQL  114

6.7.2 非关系型数据库:NoSQL  116

6.7.3 用Python 创建本地数据库  117

6.8 使用简单文件  118

6.8.1 云存储和Python  118

6.8.2 本地存储和Python  119

6.9 其他数据存储方式  119

6.10 小结  119

第7章 数据清洗:研究、匹配与格式化  121

7.1 为什么要清洗数据  121

7.2 数据清洗基础知识  122

7.2.1 找出需要清洗的数据  123

7.2.2 数据格式化  131

7.2.3 找出离群值和不良数据  135

7.2.4 找出重复值  140

7.2.5 模糊匹配  143

7.2.6 正则表达式匹配  146

7.2.7 如何处理重复记录  150

7.3 小结  151

第8章 数据清洗:标准化和脚本化  153

8.1 数据归一化和标准化  153

8.2 数据存储  154

8.3 找到适合项目的数据清洗方法  156

8.4 数据清洗脚本化  157

8.5 用新数据测试  170

8.6 小结  172

第9章 数据探索和分析  173

9.1 探索数据  173

9.1.1 导入数据  174

9.1.2 探索表函数  179

9.1.3 联结多个数据集  182

9.1.4 识别相关性  186

9.1.5 找出离群值  187

9.1.6 创建分组  189

9.1.7 深入探索  192

9.2 分析数据  193

9.2.1 分离和聚焦数据  194

9.2.2 你的数据在讲什么  196

9.2.3 描述结论  196

9.2.4 将结论写成文档  197

9.3 小结  197

第10章 展示数据  199

10.1 避免讲故事陷阱  199

10.1.1 怎样讲故事  200

10.1.2 了解听众  200

10.2 可视化数据  201

10.2.1 图表  201

10.2.2 时间相关数据  207

10.2.3 地图  208

10.2.4 交互式元素  211

10.2.5 文字  212

10.2.6 图片、视频和插画  212

10.3 展示工具  213

10.4 发布数据  213

10.4.1 使用可用站点  213

10.4.2 开源平台:创建一个新网站  215

10.4.3 Jupyter(曾名IPython notebook)  216

10.5 小结  219

第11章 网页抓取:获取并存储网络数据  221

11.1 抓取什么和如何抓取  221

11.2 分析网页  223

11.2.1 检视:标记结构  224

11.2.2 网络/ 时间线:页面是如何加载的  230

11.2.3 控制台:同JavaScript 交互  232

11.2.4 页面的深入分析  236

11.3 得到页面:如何通过互联网发出请求  237

11.4 使用Beautiful Soup 读取网页  238

11.5 使用lxml 读取网页  241

11.6 小结  249

第12章 高级网页抓取:屏幕抓取器与爬虫  251

12.1 基于浏览器的解析  251

12.1.1 使用Selenium 进行屏幕读取  252

12.1.2 使用Ghost.py 进行屏幕读取  260

12.2 爬取网页  266

12.2.1 使用Scrapy 创建一个爬虫  266

12.2.2 使用Scrapy 爬取整个网站  273

12.3 网络:互联网的工作原理,以及为什么它会让脚本崩溃  281

12.4 变化的互联网(或脚本为什么崩溃)  283

12.5 几句忠告  284

12.6 小结  284

第13章 应用编程接口  286

13.1 API 特性  287

13.1.1 REST API 与流式API  287

13.1.2 频率限制  287

13.1.3 分级数据卷  288

13.1.4 API key 和token  289

13.2 一次简单的Twitter REST API 数据拉取  290

13.3 使用Twitter REST API 进行高级数据收集  292

13.4 使用Twitter 流式API 进行高级数据收集  295

13.5 小结  297

第14章 自动化和规模化  298

14.1 为什么要自动化  298

14.2 自动化步骤  299

14.3 什么会出错  301

14.4 在哪里自动化  302

14.5 自动化的特殊工具  303

14.5.1 使用本地文件、参数及配置文件  303

14.5.2 在数据处理中使用云  308

14.5.3 使用并行处理  310

14.5.4 使用分布式处理  312

14.6 简单的自动化  313

14.6.1 CronJobs  314

14.6.2 Web 接口  316

14.6.3 Jupyter notebook  316

14.7 大规模自动化  317

14.7.1 Celery:基于队列的自动化  317

14.7.2 Ansible:操作自动化  318

14.8 监控自动化程序  319

14.8.1 Python 日志  320

14.8.2 添加自动化信息  322

14.8.3 上传和其他报告  326

14.8.4 日志和监控服务  327

14.9 没有万无一失的系统  328

14.10 小结  328

第15章 结论  330

15.1 数据处理者的职责  330

15.2 数据处理之上  331

15.2.1 成为一名更优秀的数据分析师  331

15.2.2 成为一名更优秀的开发者  331

15.2.3 成为一名更优秀的视觉化讲故事者  332

15.2.4 成为一名更优秀的系统架构师  332

15.3 下一步做什么  332

附录A 编程语言对比  334

附录B 初学者的Python 学习资源  336

附录C 学习命令行  338

附录D 高级Python 设置  349

附录E Python 陷阱  361

附录F IPython 指南  370

附录G 使用亚马逊网络服务  374

关于作者  378

关于封面  378

python数据处理PDF高清电子书的更多相关文章

  1. Python编程初学者指南PDF高清电子书免费下载|百度云盘

    百度云盘:Python编程初学者指南PDF高清电子书免费下载 提取码:bftd 内容简介 Python是一种解释型.面向对象.动态数据类型的高级程序设计语言.Python可以用于很多的领域,从科学计算 ...

  2. python数据可视化编程实战PDF高清电子书

    点击获取提取码:3l5m 内容简介 <Python数据可视化编程实战>是一本使用Python实现数据可视化编程的实战指南,介绍了如何使用Python最流行的库,通过60余种方法创建美观的数 ...

  3. Django自学教程PDF高清电子书百度云网盘免费领取

    点击获取提取码:x3di 你一定可以学会,Django 很简单! <Django自学教程>的作者学习了全部的 Django英文的官方文档,觉得国内比较好的Django学习资源不多,所以决定 ...

  4. Python数据处理PDF

    Python数据处理(高清版)PDF 百度网盘 链接:https://pan.baidu.com/s/1h8a5-iUr4mF7cVujgTSGOA 提取码:6fsl 复制这段内容后打开百度网盘手机A ...

  5. python网络爬虫高清PDF资料分享

    1.python+网络爬虫开发实战中文PDF高清版 链接:https://pan.baidu.com/s/1bks8J9kgqCArUlEoDg4acA 提取码:h9y2 复制这段内容后打开百度网盘手 ...

  6. 分享《Python 游戏编程快速上手(第3版)》高清中文版PDF+高清英文版PDF+源代码

    通过编写一个个小巧.有趣的游戏来学习Python,通过实例来解释编程的原理的方式.14个游戏程序和示例,介绍了Python基础知识.数据类型.函数.流程控制.程序调试.流程图设计.字符串操作.列表和字 ...

  7. 周志华《机器学习》高清电子书pdf分享

    周志华<机器学习>高清电子书pdf下载地址 下载地址1:https://545c.com/file/20525574-415455837 下载地址2: https://pan.baidu. ...

  8. 疯狂Python讲义PDF高清完整版免费下载|百度网盘

    百度网盘:疯狂Python讲义PDF高清完整版免费下载 提取码:uzba 内容简介 <疯狂Python讲义>既是一本适合初学者入门Python的图书(一个8岁的小朋友在未出版前已学习了本书 ...

  9. 电脑报2014年第43期 pdf高清版

    电脑报2014年第43期 pdf高清版

随机推荐

  1. CF833A The Meaningless Game 题解

    题目 Slastyona and her loyal dog Pushok are playing a meaningless game that is indeed very interesting ...

  2. NIVIDIA Tegra K1 QWT安装使用问题和解决办法

    在Linux系统下,Tegra K1(ARM体系),只有QtCreator的环境下,去安装Qwt6.1.0: 下载: 系统安装好之后,直接联网在系统自带的软件安装程序中搜索Qt,安装Qt5.2.1,之 ...

  3. pigctf期末测评

    pigctf期末测评 MISC 1 拿到图片,先binwalk一下,如下图 果然发现png图片后面跟了个ZIP,然后提取出来打开发现了一个flag.png,然后查看16进制文件没有发现什么问题,之后查 ...

  4. 数据可视化之powerBI基础(四)深入了解PowerBI的工具提示功能

    https://zhuanlan.zhihu.com/p/36804592 在PowerBI上个月的更新中,增加了工具提示功能,这项功能允许您将自己的可视化作品放置到工具提示中,通过鼠标悬停的方式来展 ...

  5. JavaScript之setinterval的具体使用

    关于setInterval在api文档中也有很详细的解释,比如下面那两个: setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式. setInterval() 方法会不停 ...

  6. 关于Haskell计算斐波那契数列的思考

    背景 众所周知,Haskell语言是一门函数式编程语言.函数式编程语言的一大特点就是数值和对象都是不可变的,而这与经常需要对状态目前的值进行修改的动态规划算法似乎有些"格格不入", ...

  7. Ethical Hacking - NETWORK PENETRATION TESTING(5)

    Deauthentication Attacks Theory This attack is used to disconnect any device from any network within ...

  8. C++语法小记---运算符重载

    运算符重载 运算符重载的本质也是对已有功能的扩展 运算符重载的本质就是函数重载,只是函数变成了 operator + 运算符 当成员函数和全局函数对运算符进行重载时,优先调用成员函数 运算符重载为成员 ...

  9. spring读取jdbc(file方式)

    使用PropertyPlaceholderConfigurer类载入外部配置 在Spring项目中,你可能需要从properties文件中读入配置注入到bean中,例如数据库连接信息,memcache ...

  10. Prime Ring Problem--------多重循环用递归来做

    链接:https://vjudge.net/problem/UVA-524 题意:给出正整数n,输出以1开头,由2到n组合的字符序列,使相邻的数相加为素数,最后一个(关键信息为n大于1小于等于16), ...