《Python程序设计与算法基础教程》PDF下载

  • 购买积分:14 如何计算积分?
  • 作  者:江红,余青松主编
  • 出 版 社:北京:清华大学出版社
  • 出版年份:2017
  • ISBN:9787302466833
  • 页数:401 页
图书介绍:本教程集“教材、练习册、上机指导”于一体,基于Windows 7和Python 3.3.2构建Python开发平台,阐述Python语言的基础知识,以及使用Python语言的实际开发应用实例。

第1章Python概述 1

1.1 Python语言概述 1

1.1.1 Python语言简介 1

1.1.2 Python语言的特点 1

1.1.3 Python语言的应用范围 2

1.2 Python语言版本和开发环境 2

1.2.1 Python语言的版本 2

1.2.2 Python语言的实现 2

1.2.3 Python语言的集成开发环境 3

1.3下载和安装Python 3

1.3.1下载Python 3

1.3.2安装Python 4

1.3.3安装和管理Python扩展包 4

1.4使用Python解释器解释执行Python程序 6

1.4.1运行Python解释器 6

1.4.2运行Python集成开发环境 7

1.5使用文本编辑器和命令行编写和执行Python源文件程序 8

1.5.1编写Hello World程序 9

1.5.2 Hello World程序(hello.py )源代码分析 10

1.5.3运行Python源代码程序 10

1.5.4命令行参数 11

1.6使用集成开发环境IDLE编写和执行Python源文件程序 12

1.6.1使用IDLE编写程序 12

1.6.2使用IDLE编辑程序 13

1.7在线帮助和相关资源 13

1.7.1 Python交互式帮助系统 13

1.7.2 Python文档 16

1.7.3 Python官网 17

1.7.4 Python扩展库索引(PyPI) 17

复习题 18

上机实践 19

第2章Python语言基础 20

2.1 Python程序概述 20

2.1.1引例 20

2.1.2 Python程序构成 20

2.2 Python对象和引用 21

2.2.1 Python对象概述 21

2.2.2使用字面量创建实例对象 21

2.2.3使用类对象创建实例对象 22

2.2.4数据类型 22

2.2.5变量和对象的引用 22

2.2.6 Python是动态类型语言 23

2.2.7 Python是强类型语言 24

2.2.8对象内存示意图 24

2.2.9对象的值比较(==)和引用判别(is) 25

2.2.10不可变对象(immutable)和可变对象(mutable) 25

2.3标识符及其命名规则 26

2.3.1标识符 26

2.3.2保留关键字 27

2.3.3 Python预定义标识符 27

2.3.4命名规则 27

2.4变量和赋值语句 28

2.4.1变量的声明和赋值 28

2.4.2链式赋值语句 28

2.4.3复合赋值语句 29

2.4.4删除变量 29

2.4.5系列解包赋值 29

2.4.6常量 30

2.5表达式和运算符 30

2.5.1表达式的组成 30

2.5.2表达式的书写规则 31

2.5.3运算符概述 31

2.5.4 Python运算符及其优先级 31

2.6语句 32

2.6.1 Python语句 32

2.6.2 Python语句的书写规则 33

2.6.3复合语句及其缩进书写规则 33

2.6.4注释语句 34

2.6.5空语句pass 34

2.7函数和模块 34

2.7.1函数的创建和调用 34

2.7.2内置函数 35

2.7.3模块函数 35

2.7.4函数API 36

2.8类和对象 36

2.8.1创建类对象 36

2.8.2实例对象的创建和调用 37

2.9模块和包 37

复习题 37

上机实践 39

第3章 程序流程控制 41

3.1顺序结构 41

3.2选择结构 41

3.2.1分支结构的形式 42

3.2.2单分支结构 42

3.2.3双分支结构 43

3.2.4多分支结构 44

3.2.5 if语句的嵌套 45

3.2.6 if语句典型示例代码 46

3.2.7选择结构综合举例 47

3.3循环结构 48

3.3.1可迭代对象 48

3.3.2 range对象 49

3.3.3 for循环 49

3.3.4 while循环 50

3.3.5循环的嵌套 51

3.3.6 break语句 52

3.3.7 continue语句 53

3.3.8死循环(无限循环) 54

3.3.9 else子句 55

3.3.10循环语句典型示例代码 55

3.3.11循环结构综合举例 56

复习题 57

上机实践 60

第4章 常用内置数据类型 64

4.1 Python内置数据类型概述 64

4.1.1数值数据类型 64

4.1.2序列数据类型 64

4.1.3集合数据类型 65

4.1.4字典数据类型 65

4.1.5 NoneType、 NotImplementedType和E1lipsisType 65

4.1.6其他数据类型 65

4.2 int数据类型(任意精度整数) 65

4.2.1整型字面量 66

4.2.2 int对象 66

4.2.3 int对象的方法 66

4.2.4整数的运算 67

4.3 float类型(有限精度浮点数) 68

4.3.1浮点类型字面量 68

4.3.2 float对象 68

4.3.3 float对象的方法 68

4.3.4浮点数的运算 69

4.4 complex类型(复数) 70

4.4.1复数类型字面量 70

4.4.2 complex对象 70

4.4.3 complex对象属性和方法 70

4.4.4复数的运算 70

4.5 bool数据类型(布尔逻辑值) 71

4.5.1布尔值字面量 71

4.5.2 bool对象 71

4.5.3逻辑运算符 72

4.6 str数据类型(字符串) 73

4.6.1字符串字面量 73

4.6.2字符串编码 73

4.6.3转义字符 73

4.6.4 str对象 74

4.6.5 str对象属性和方法 74

4.6.6字符串的运算 75

4.6.7对象转换为字符串 75

4.6.8字符串的格式化 75

4.7比较关系运算和条件表达式 76

4.7.1条件表达式 76

4.7.2关系和测试运算符 77

4.8算术运算符和位运算符 78

4.8.1算术运算符 78

4.8.2位运算符 78

4.9混合运算和数值类型转换 79

4.9.1隐式转换 79

4.9.2显式转换(强制转换) 79

4.10内置标准数学函数 80

4.10.1内置数学运算函数 80

4.10.2数制转换函数 80

复习题 81

上机实践 84

第5章 系列数据类型 89

5.1 Python系列数据概述 89

5.1.1数组 89

5.1.2系列数据类型 89

5.2系列数据的基本操作 90

5.2.1系列的长度、最大值、最小值、求和 90

5.2.2系列的索引访问操作 90

5.2.3系列的切片操作 91

5.2.4系列的连接和重复操作 92

5.2.5系列的成员关系操作 92

5.2.6系列的比较运算操作 93

5.2.7系列的排序操作 94

5.2.8内置函数all()和any() 94

5.2.9系列拆封 94

5.3元组 95

5.3.1使用元组字面量创建元组实例对象 95

5.3.2使用tuple对象创建元组实例对象 96

5.3.3元组的系列操作 96

5.4列表 96

5.4.1使用列表字面量创建列表实例对象 96

5.4.2使用list对象创建元组实例对象 97

5.4.3列表的系列操作 97

5.4.4 list对象的方法 97

5.4.5列表解析表达式 98

5.5字符串 98

5.5.1字符串的系列操作 98

5.5.2字符串编码 99

5.5.3字符串格式化 99

5.6字节系列 102

5.6.1 bytes常量 102

5.6.2创建bytes对象 102

5.6.3创建bytearray对象 103

5.6.4 bytes和bytearray的系列操作 103

5.6.5字节编码和解码 104

复习题 104

上机实践 106

第6章 输入和输出 108

6.1输入和输出概述 108

6.2命令行参数 108

6.2.1 sys.argv与命令行参数 108

6.2.2 argparse模块和命令行参数解析 109

6.3标准输入和标准输出函数 110

6.3.1输入和输出函数 110

6.3.2交互式用户输入 111

6.3.3运行时提示输入密码 112

6.4文件和文件对象 112

6.4.1文件对象和open函数 112

6.4.2文件的打开、写入、读取和关闭 113

6.4.3 with语句和上下文管理协议 113

6.5标准输入、输出和错误流 114

6.5.1标准输入、输出和错误流文件对象 114

6.5.2读取任意长度的输入流 115

6.5.3标准输入、输出和错误流重定向 115

6.6重定向和管道 116

6.6.1重定向标准输出到一个文件 117

6.6.2重定向文件到标准输入 117

6.6.3管道 118

6.6.4过滤器 119

复习题 121

上机实践 121

第7章 错误和异常处理 123

7.1程序的错误 123

7.1.1语法错误 123

7.1.2运行时错误 123

7.1.3逻辑错误 124

7.2异常处理 125

7.2.1异常处理概述 125

7.2.2内置的异常类 125

7.2.3引发异常 127

7.2.4捕获处理异常机制概述 128

7.2.5 Python虚拟机捕获处理异常 128

7.2.6使用try …except…else …fiinally语句捕获处理异常 128

7.2.7捕获异常的顺序 129

7.2.8 fiinally块和发生异常后的处理 130

7.2.9自定义异常类 130

7.3断言处理 131

7.3.1断言处理概述 131

7.3.2 assert语句和AssertionError类 131

7.3.3启用/禁用断言 132

7.4程序的基本调试方法 132

7.4.1语法错误的调试 133

7.4.2运行时错误的调试 133

7.4.3逻辑错误的调试 134

复习题 134

上机实践 135

第8章 函数 137

8.1函数概述 137

8.1.1函数的基本概念 137

8.1.2函数的功能 137

8.1.3 Python函数分类 137

8.2函数的声明和调用 138

8.2.1函数对象的创建 138

8.2.2函数的调用 139

8.2.3作为对象的函数 140

8.2.4 Lamda表达式和匿名函数 140

8.2.5函数的副作用 141

8.3参数的传递 141

8.3.1形式参数和实际参数 141

8.3.2形式参数变量和对象引用传递 142

8.3.3传递不可变对象的引用 142

8.3.4传递可变对象的引用 143

8.3.5可选参数 143

8.3.6位置参数和命名参数 144

8.3.7可变参数 145

8.3.8强制命名参数 145

8.3.9参数类型检查 146

8.4函数的返回值 146

8.4.1 return语句和函数返回值 146

8.4.2多条return语句 147

8.4.3返回多个值 148

8.5变量的作用域 148

8.5.1全局变量 148

8.5.2局部变量 149

8.5.3全局语句global 150

8.5.4非局部语句nonlocal 151

8.5.5类成员变量 151

8.5.6输出局部变量和全局变量 151

8.6递归函数 152

8.6.1递归函数的定义 152

8.6.2递归函数的原理 153

8.6.3递归函数需要注意的问题 154

8.6.4递归函数的应用:最大公约数 154

8.6.5递归函数的应用:汉诺塔 155

8.7内置函数的使用 156

8.7.1内置函数一览 156

8.7.2 eval函数 156

8.7.3 exec函数 157

8.7.4 compile函数 157

复习题 157

上机实践 159

第9章 类和对象 161

9.1面向对象概念 161

9.1.1对象的定义 161

9.1.2封装 161

9.1.3继承 161

9.1.4多态性 161

9.2类对象和实例对象 162

9.2.1类对象 162

9.2.2实例对象 162

9.3属性 163

9.3.1实例属性 163

9.3.2类属性 164

9.3.3私有属性和公有属性 164

9.3.4@property装饰器 165

9.3.5特殊属性 167

9.3.6自定义属性 167

9.4方法 168

9.4.1实例方法 168

9.4.2静态方法 169

9.4.3类方法 170

9.4.4 init方法(构造函数)和new方法 171

9.4.5 del方法(析构函数) 172

9.4.6私有方法与公有方法 173

9.4.7方法重载 173

9.5继承 174

9.5.1派生类 174

9.5.2查看继承的层次关系 175

9.5.3类成员的继承和重写 176

9.6对象的特殊方法 176

9.6.1对象的特殊方法概述 176

9.6.2运算符重载与对象的特殊方法 177

9.6.3@functools.total_ordering装饰器 179

9.6.4 call方法和可调用对象 179

9.7对象的引用、浅拷贝和深拷贝 180

9.7.1对象的引用 180

9.7.2对象的浅拷贝 180

9.7.3对象的深拷贝 181

复习题 181

上机实践 183

第10章 模块和客户端 185

10.1模块化程序设计的概念 185

10.1.1模块化程序设计 185

10.1.2模块的API 185

10.1.3模块的实现 186

10.1.4模块的客户端 187

10.1.5模块化程序设计的优越性 187

10.2模块的设计和实现 188

10.2.1模块设计的一般原则 188

10.2.2 API设计 188

10.2.3创建模块 188

10.2.4模块的私有函数 189

10.2.5模块的测试代码 190

10.2.6编写模块文档字符串 191

10.2.7按字节编译的.pyc文件 192

10.3模块的导入和使用 192

10.3.1导入模块和使用模块 192

10.3.2导入模块中的成员 192

10.3.3重新加载模块 193

10.3.4动态代入模块 193

10.4包 194

10.4.1包的概念 194

10.4.2创建包 194

10.4.3包的导入和使用 195

10.5模块的导入顺序 195

10.5.1导入模块时的搜索顺序 195

10.5.2模块搜索路径sys.path 196

10.5.3 dir()内置函数 197

10.6命名空间与名称查找顺序 198

复习题 198

上机实践 199

第11章 算法与数据结构基础 200

11.1算法及其性能分析 200

11.1.1算法概述 200

11.1.2算法的时间复杂度分析 200

11.1.3增长量级 201

11.1.4算法的空间复杂度分析 202

11.2查找算法 202

11.2.1顺序查找法 202

11.2.2二分查找法 204

11.2.3 Python语言提供的查找算法 205

11.3排序算法 205

11.3.1冒泡排序法 205

11.3.2选择排序法 206

11.3.3插入排序法 207

11.3.4归并排序法 208

11.3.5快速排序法 210

11.3.6 Python语言提供的排序算法 211

11.4常用数据结构 211

11.4.1数据结构概述 211

11.4.2常用的数据结构概述 212

11.4.3 Python的collections模块 212

11.5数组 213

11.5.1列表和数组 213

11.5.2 array.array对象和数组 213

11.6栈和队列 214

11.6.1栈的实现:使用列表 214

11.6.2 deque对象 215

11.6.3 deque作为栈 216

11.6.4 deque作为队列 216

11.7集合 217

11.7.1集合的定义 217

11.7.2判断集合元素是否存在 217

11.7.3集合的运算:并集、交集、差集和对称差集 218

11.7.4集合的比较运算:相等、子集和超集 218

11.7.5集合的长度、最大值、最小值、元素和 219

11.7.6可变集合的方法 219

11.8字典(映射) 220

11.8.1对象的哈希值 220

11.8.2字典的定义 220

11.8.3字典的访问操作 221

11.8.4字典的视图对象 221

11.8.5判断字典键是否存在 221

11.8.6字典对象的长度和比较 221

11.8.7字典对象的方法 222

11.8.8 defaultdict对象 222

11.8.9 OrderedDict对象 223

11.8.10 ChainMap对象 223

11.8.11 Counter对象 224

11.9 collections模块的其他数据结构 226

11.9.1 namedtuple对象 226

11.9.2 UserDict、 UserList和UserString对象 227

复习题 227

上机实践 230

第12章 图形用户界面 233

12.1图形用户界面概述 233

12.1.1 tkinter 233

12.1.2其他GUI库简介 233

12.2 tkinter概述 234

12.2.1 tkinter模块 234

12.2.2图形用户界面构成 234

12.2.3框架和GUI应用程序类 235

12.2.4 tkinter主窗口 236

12.3几何布局管理器 236

12.3.1 pack几何布局管理器 237

12.3.2grid几何布局管理器 237

12.3.3 place几何布局管理器 239

12.4事件处理 240

12.4.1事件类型 240

12.4.2事件绑定 240

12.4.3事件处理函数 241

12.5常用组件 242

12.5.1 Label 242

12.5.2 LabelFrame 242

12.5.3 Button 243

12.5.4 Message 244

12.5.5 Entry 245

12.5.6 Text 245

12.5.7 Radiobutton 247

12.5.8 Checkbutton 247

12.5.9 Listbox 250

12.5.10 OptionMenu 251

12.5.11 Scale 253

12 5.12 Toplevel 254

12.5.13 ttk子模块控件 254

12.6对话框 255

12.6.1通用消息对话框 255

12.6.2文件对话框 256

12.6.3颜色选择对话框 257

12.6.4通用对话框应用举例 258

12.6.5简单对话框 259

12.7菜单和工具栏 260

12.7.1创建主菜单 260

12.7.2创建上下文菜单 262

12.7.3菜单应用举例 263

复习题 265

上机实践 266

第13章 图形绘制 268

13.1 Python绘图模块概述 268

13.2基于tkinter的图形绘制 269

13.2.1基于tkinter画布绘图概述 269

13.2.2创建画布对象 269

13.2.3绘制矩形 270

13.2.4绘制椭圆 270

13.2.5绘制圆弧 271

13.2.6绘制线条 271

13.2.7绘制多边形 272

13.2.8绘制字符串 273

13.2.9应用举例:函数图形 273

13.3基于turtle模块的海龟绘图 274

13.3.1海龟绘图概述 274

13.3.2 turtle模块概述 274

13.3.3绘制正方形 275

13.3.4绘制多边形 275

13.3.5绘制圆形螺旋 276

13.3.6递归图形 277

13.3.7海龟绘图的应用实例 278

13.4基于Matplotlib模块的绘图 279

13.4.1 Matplotlib模块概述 279

13.4.2安装Matplotlib模块 279

13.4.3使用Matplotlib模块绘图概述 280

13.4.4绘制函数曲线 280

13.4.5绘制多个图形 281

13.4.6绘制直方图 282

复习题 283

上机实践 284

第14章 数值日期和时间处理 286

14.1相关模块概述 286

14.1.1数值处理的相关模块 286

14.1.2日期和时间处理的相关模块 286

14.2 math模块和数学函数 286

14.2.1 math模块的API 286

14.2.2 math模块应用举例 289

14.3 cmath模块和复数数学函数 290

14.4 random模块和随机函数 291

14.4.1种子和随机状态 291

14.4.2随机整数 292

14.4.3随机系列 293

14.5数值运算模块NumPy 293

14.5.1数值运算模块的基本使用 293

14.5.2创建数组 294

14.5.3处理数组 295

14.5.4数组应用举例 295

14.6日期和时间处理 295

14.6.1相关术语 295

14.6.2时间对象 296

14.6.3测量程序运行时间 296

14.6.4日期对象 297

14.6.5获取当前日期时间 297

14.6.6日期时间格式化为字符串 298

14.6.7日期时间字符串解析为日期时间对象 298

复习题 299

上机实践 300

第15章 字符串和文本处理 303

15.1相关模块概述 303

15.1.1字符串和文本处理的相关模块 303

15.1.2字符串处理概述的常用方法 303

15.2字符串处理的常用操作 303

15.2.1字符串的类型判断 303

15.2.2字符串大小写转换 304

15.2.3字符串的填充、空白和对齐 304

15.2.4字符串的测试、查找和替换 305

15.2.5字符串的拆分和组合 305

15.2.6字符串的翻译和转换 306

15.2.7字符串应用举例 306

15.3正则表达式 307

15.3.1正则表达式语言概述 307

15.3.2正则表达式引擎 308

15.3.3普通字符和转义字符 308

15.3.4字符类和预定义字符类 309

15.3.5边界匹配符 309

15.3.6重复限定符 310

15.3.7匹配算法:贪婪和懒惰 310

15.3.8选择分支 311

15.3.9分组和向后引用 311

15.3.10正则表达式的匹配模式 313

15.3.11常用正则表达式 313

15.4正则表达式模块re 313

15.4.1匹配和搜索函数 313

15.4.2匹配选项 314

15.4.3正则表达式对象 314

15.4.4匹配对象 315

15.4.5匹配和替换 316

15.4.6分割字符串 316

15.5正则表达式应用举例 316

15.5.1字符串包含验证 316

15.5.2字符串查找和拆分 317

15.5.3字符串替换和清除 318

15.5.4字符串查找和截取 318

复习题 319

上机实践 320

第16章 文件 322

16.1文件操作相关模块概述 322

16.2文本文件的读取和写入 322

16.2.1文本文件的写入 322

16.2.2文本文件的读取 323

16.2.3文本文件的编码 324

16.3二进制文件的读取和写入 325

16.3.1二进制文件的写入 325

16.3.2二进制文件的读取 326

16.4随机文件访问 326

16.5内存文件的操作 328

16.5.1 StringIO和内存文本文件操作 328

16.5.2 BytesIO和内存文本文件操作 328

16.6文件的压缩和解压缩 329

16.7 CSV文件格式的读取和写入 329

16.7.1 csv .reader对象和csv文件的读取 330

16.7.2 csv .writer对象和csv文件的写入 330

16.7.3 csv .DictReader对象和csv文件的读取 331

16.7.4 csv.DictWriter对象和csv文件的写入 332

16.7.5 csv文件格式化参数和Dialect对象 332

16.8 os模块和文件访问 334

16.8.1文件描述符 334

16.8.2使用os模块提供的函数访问文件 334

16.9输入重定向和管道 335

16.9.1 FileInput对象 335

16.9.2 fiileinput模块的函数 336

16.9.3输入重定向 337

16.10对象系列化 338

16.10.1对象系列化概念 338

16.10.2 pickle模块和对象系列化 338

复习题 339

上机实践 340

第17章 数据库访问 341

17.1数据库基础 341

17.1.1数据库概念 341

17.1.2关系数据库 341

17.2 Python数据库访问模块 342

17.2.1通用数据库访问模块 342

17.2.2专用数据库访问模块 343

17.2.3 SQLite数据库和sqlite3模块 343

17.3使用sqlite3模块连接和操作SQLite数据库 344

17.3.1访问数据库的典型步骤 344

17.3.2创建数据库和表 346

17.3.3数据库表的插入、更新和删除操作 346

17.3.4数据库表的查询操作 347

复习题 347

上机实践 348

第18章 网络编程和通信 349

18.1网络编程的基本概念 349

18.1.1网络基础知识 349

18.1.2 TCP/IP简介 349

18.1.3 IP地址和域名 350

18.1.4统一资源定位器URL 351

18.2基于socket的网络编程 352

18.2.1 socket概述 352

18.2.2创建socket对象 353

18.2.3将服务器端socket绑定到指定地址上 353

18.2.4服务器端socket开始侦听 354

18.2.5连接和接收连接 355

18.2.6发送和接收数据 355

18.2.7简单TCP程序:Echo Server 355

18.2.8简单UDP程序:Echo Server 357

18.2.9 UDP程序:Quote Server 358

18.3基于urllib的网络编程 359

18.3.1打开和读取URL网络资源 359

18.3.2创建Request对象 359

18.4基于http的网络编程 360

18.5基于ftplib的网络编程 360

18.5.1创建FTP对象 361

18.5.2创建FTP TLS对象 362

18.6基于poplib和smtplib的网络编程 363

18.6.1使用poplib接收邮件 363

18.6.2使用smtplib发送邮件 363

复习题 364

上机实践 365

第19章 多线程编程 367

19.1线程处理概述 367

19.1.1进程和线程 367

19.1.2线程的优缺点 367

19.2创建和启动多线程 368

19.2.1使用start_new _thread函数创建线程 368

19.2.2使用Thread对象创建线程 368

19.2.3自定义派生于Thread的对象 370

19.2.4线程加入join() 370

19.2.5用户线程和daemon线程 371

19.3线程同步 373

19.3.1线程同步处理 373

19.3.2基于原语锁(Lock/RLock对象)的简单同步 373

19.3.3基于条件变量(Condition对象)的同步和通信 375

复习题 377

上机实践 378

第20章 系统管理 379

20.1系统管理相关模块 379

20.2目录、文件和磁盘的基本操作 379

20.2.1创建目录 379

20.2.2临时目录和文件的创建 379

20.2.3切换当前工作目录 380

20.2.4目录内容列表 380

20.2.5文件通配符和glob.glob函数 380

20.2.6遍历目录和os.walk函数 381

20.2.7判断文件/目录是否存在 381

20.2.8测试文件类型 382

20.2.9文件的日期及其大小 382

20.2.10文件和目录的删除 382

20.2.11文件和目录复制、重命名和移动 383

20.2.12磁盘的基本操作 383

20.3执行操作系统命令和运行其他程序 383

20.3.1 os.system函数 383

20.3.2 os.popen函数 384

20.3.3 subprocess模块 384

20.4获取终端的大小 385

20.5文件压缩和解压缩 386

20.5.1 shutil模块支持的压缩和解压缩格式 386

20.5.2 make archive()和文件压缩 386

20.5.3 unpack archive()函数和文件解压缩 387

20.6 confiigparser模块和配置文件 387

20.6.1 INI文件及INI文件格式 387

20.6.2 ConfigParser对象和INI文件操作 388

复习题 389

上机实践 390

附录 复习题参考答案 391

参考文献 400