像计算机科学家一样思考Python(第2版)
Allen B. Downey
赵普明 译
出版时间:2016年06月
页数:226
如果想要学习如何编程,从Python语言入手是一个很好的开端。本书从基本的编程概念开始,一步步引导读者了解Python语言,再逐渐掌握函数、递归、数据结构和面向对象设计等高阶概念。本书第2版及其辅助代码均已升级,支持Python 3。
每章后的练习可以帮助读者加深对刚学的编程概念的理解。本书是高中和大学阶段的学生、自学者,以及需要了解编程基础的专业人士的理想读物。初学者可以在浏览器中学习如何开始Python编程。

● 从基础开始,包括语言的语法和语义。
● 掌握每一个编程概念的清晰定义。
● 循序渐进地学习值、变量、语句、函数和数据结构。
● 了解如何操作文件和数据库。
● 理解对象、方法和面向对象编程。
● 使用各种调试技巧来修复语法错误、运行时错误和语义错误。
● 通过一系列案例研究来探索函数、数据结构和算法。

“这是一本读起来令人十分愉悦的书。Allen Downey的解释清晰明了,而且他设计的练习可以吸引并启发各种背景的读者。”
——Luciano Ramalho
ThoughtWorks的技术负责人
Fluent Python的作者
  1. 第1章 程序之道 
  2. 1.1 什么是程序 
  3. 1.2 运行Python 
  4. 1.3 第一个程序 
  5. 1.4 算术操作符 
  6. 1.5 值和类型 
  7. 1.6 形式语言和自然语言 
  8. 1.7 调试 
  9. 1.8 术语表 
  10. 1.9 练习 
  11. 第2章 变量、表达式和语句
  12. 2.1 赋值语句
  13. 2.2 变量名称
  14. 2.3 表达式和语句
  15. 2.4 脚本模式
  16. 2.5 操作顺序
  17. 2.6 字符串操作
  18. 2.7 注释
  19. 2.8 调试
  20. 2.9 术语表
  21. 2.10 练习
  22. 第3章 函数
  23. 3.1 函数调用
  24. 3.2 数学函数
  25. 3.3 组合
  26. 3.4 添加新函数
  27. 3.5 定义和使用
  28. 3.6 执行流程
  29. 3.7 形参和实参
  30. 3.8 变量和形参是局部的
  31. 3.9 栈图
  32. 3.10 有返回值函数和无返回值函数
  33. 3.11 为什么要有函数
  34. 3.12 调试
  35. 3.13 术语表
  36. 3.14 练习
  37. 第4章 案例研究:接口设计
  38. 4.1 turtle模块
  39. 4.2 简单重复
  40. 4.3 练习
  41. 4.4 封装
  42. 4.5 泛化
  43. 4.6 接口设计
  44. 4.7 重构
  45. 4.8 一个开发计划
  46. 4.9 文档字符串
  47. 4.10 调试
  48. 4.11 术语表
  49. 4.12 练习
  50. 第5章 条件和递归
  51. 5.1 向下取整除法操作符和求模操作符
  52. 5.2 布尔表达式
  53. 5.3 逻辑操作符
  54. 5.4 条件执行
  55. 5.5 选择执行
  56. 5.6 条件链
  57. 5.7 嵌套条件
  58. 5.8 递归
  59. 5.9 递归函数的栈图
  60. 5.10 无限递归
  61. 5.11 键盘输入
  62. 5.12 调试
  63. 5.13 术语表
  64. 5.14 练习
  65. 第6章 有返回值的函数
  66. 6.1 返回值
  67. 6.2 增量开发
  68. 6.3 组合
  69. 6.4 布尔函数
  70. 6.5 再谈递归
  71. 6.6 坚持信念
  72. 6.7 另一个示例
  73. 6.8 检查类型
  74. 6.9 调试
  75. 6.10 术语表
  76. 6.11 练习
  77. 第7章 迭代
  78. 7.1 重新赋值
  79. 7.2 更新变量
  80. 7.3 while语句
  81. 7.4 break语句
  82. 7.5 平方根
  83. 7.6 算法
  84. 7.7 调试
  85. 7.8 术语表
  86. 7.9 练习
  87. 第8章 字符串
  88. 8.1 字符串是一个序列
  89. 8.2 len
  90. 8.3 使用for循环进行遍历
  91. 8.4 字符串切片
  92. 8.5 字符串是不可变的
  93. 8.6 搜索
  94. 8.7 循环和计数
  95. 8.8 字符串方法
  96. 8.9 操作符in
  97. 8.10 字符串比较
  98. 8.11 调试
  99. 8.12 术语表
  100. 8.13 练习
  101. 第9章 案例分析:文字游戏
  102. 9.1 读取单词列表
  103. 9.2 练习
  104. 9.3 搜索
  105. 9.4 使用下标循环
  106. 9.5 调试
  107. 9.6 术语表
  108. 9.7 练习
  109. 第10章 列表
  110. 10.1 列表是一个序列
  111. 10.2 列表是可变的
  112. 10.3 遍历一个列表
  113. 10.4 列表操作
  114. 10.5 列表切片
  115. 10.6 列表方法
  116. 10.7 映射、过滤和化简
  117. 10.8 删除元素
  118. 10.9 列表和字符串
  119. 10.10 对象和值
  120. 10.11 别名
  121. 10.12 列表参数
  122. 10.13 调试
  123. 10.14 术语表
  124. 10.15 练习
  125. 第11章 字典
  126. 11.1 字典是一种映射
  127. 11.2 使用字典作为计数器集合
  128. 11.3 循环和字典
  129. 11.4 反向查找
  130. 11.5 字典和列表
  131. 11.6 备忘
  132. 11.7 全局变量
  133. 11.8 调试
  134. 11.9 术语表
  135. 11.10 练习
  136. 第12章 元组
  137. 12.1 元组是不可变的
  138. 12.2 元组赋值
  139. 12.3 作为返回值的元组
  140. 12.4 可变长参数元组
  141. 12.5 列表和元组
  142. 12.6 字典和元组
  143. 12.7 序列的序列
  144. 12.8 调试
  145. 12.9 术语表
  146. 12.10 练习
  147. 第13章 案例研究:选择数据结构
  148. 13.1 单词频率分析
  149. 13.2 随机数
  150. 13.3 单词直方图
  151. 13.4 最常用的单词
  152. 13.5 可选形参
  153. 13.6 字典减法
  154. 13.7 随机单词
  155. 13.8 马尔可夫分析
  156. 13.9 数据结构
  157. 13.10 调试
  158. 13.11 术语表
  159. 13.12 练习
  160. 第14章 文件
  161. 14.1 持久化
  162. 14.2 读和写
  163. 14.3 格式操作符
  164. 14.4 文件名和路径
  165. 14.5 捕获异常
  166. 14.6 数据库
  167. 14.7 封存
  168. 14.8 管道
  169. 14.9 编写模块
  170. 14.10 调试
  171. 14.11 术语表
  172. 14.12 练习
  173. 第15章 类和对象
  174. 15.1 用户定义类型
  175. 15.2 属性
  176. 15.3 矩形
  177. 15.4 作为返回值的实例
  178. 15.5 对象是可变的
  179. 15.6 复制
  180. 15.7 调试
  181. 15.8 术语表
  182. 15.9 练习
  183. 第16章 类和函数
  184. 16.1 时间
  185. 16.2 纯函数
  186. 16.3 修改器
  187. 16.4 原型和计划
  188. 16.5 调试
  189. 16.6 术语表
  190. 16.7 练习
  191. 第17章 类和方法
  192. 17.1 面向对象特性
  193. 17.2 打印对象
  194. 17.3 另一个示例
  195. 17.4 一个更复杂的示例
  196. 17.5 init方法
  197. 17.6 _ _str_ _方法
  198. 17.7 操作符重载
  199. 17.8 基于类型的分发
  200. 17.9 多态
  201. 17.10 接口和实现
  202. 17.11 调试
  203. 17.12 术语表
  204. 17.13 练习
  205. 第18章 继承
  206. 18.1 卡片对象
  207. 18.2 类属性
  208. 18.3 对比卡牌
  209. 18.4 牌组
  210. 18.5 打印牌组
  211. 18.6 添加、删除、洗牌和排序
  212. 18.7 继承
  213. 18.8 类图
  214. 18.9 数据封装
  215. 18.10 调试
  216. 18.11 术语表
  217. 18.12 练习
  218. 第19章 Python拾珍
  219. 19.1 条件表达式
  220. 19.2 列表理解
  221. 19.3 生成器表达式
  222. 19.4 any和all
  223. 19.5 集合
  224. 19.6 计数器
  225. 19.7 defaultdict
  226. 19.8 命名元组
  227. 19.9 收集关键词参数
  228. 19.10 术语表
  229. 19.11 练习
  230. 第20章 调试
  231. 20.1 语法错误
  232. 20.2 运行时错误
  233. 20.2.1 我的程序什么都不做
  234. 20.2.2 我的程序卡死了
  235. 20.2.3 无限循环
  236. 20.2.4 无限递归
  237. 20.2.5 执行流程
  238. 20.2.6 当我运行程序,会得到一个异常
  239. 20.2.7 我添加了太多print语句,被输出淹没了 
  240. 20.3 语义错误
  241. 20.3.1 我的程序运行不正确
  242. 20.3.2 我有一个巨大而复杂的表达式,而它和我预料的不同
  243. 20.3.3 我有一个函数,返回值和预期不同
  244. 20.3.4 我真的真的卡住了,我需要帮助
  245. 20.3.5 不行,我真的需要帮助
  246. 第21章 算法分析
  247. 21.1 增长量级
  248. 21.2 Python基本操作的分析
  249. 21.3 搜索算法的分析
  250. 21.4 散列表
  251. 21.5 术语表
  252. 译后记
书名:像计算机科学家一样思考Python(第2版)
作者:Allen B. Downey
译者:赵普明 译
国内出版社:人民邮电出版社
出版时间:2016年06月
页数:226
书号:978-7-115-42551-5
原版书书名:Think Python, 2nd Edition
原版书出版商:O'Reilly Media
Allen B. Downey
 
allen downey是欧林工程学院的计算机科学教授。他从加州大学伯克利分校获得计算机科学博士学位,从mit获得学士和硕士学位。他曾在韦尔斯利学院、科尔比学院及加州大学伯克利分校教授计算机科学课程。他基于自己教授计算机程序设计课程的经验,开创了“像计算机科学家一样思考”(how to think like a computer scientist)的教学理念和方法,并藉此编写了多本编程语言书籍。