1、Python 程序设计习题与参考答案第 1 章 基础知识1.1 简单说明如何选择正确的 Python 版本。答:在选择 Python 的时候,一定要先考虑清楚自己学习 Python 的目的是什么,打算做哪方面的开发,有哪些扩展库可用,这些扩展库最高支持哪个版本的 Python,是 Python 2.x还是 Python 3.x,最高支持到 Python 2.7.6 还是 Python 2.7.9。这些问题都确定以后,再做出自己的选择,这样才能事半功倍,而不至于把大量时间浪费在 Python 的反复安装和卸载上。同时还应该注意,当更新的 Python 版本推出之后,不要急于更新,而是应该等确定自
2、己所必须使用的扩展库也推出了较新版本之后再进行更新。尽管如此,Python 3 毕竟是大势所趋,如果您暂时还没想到要做什么行业领域的应用开发,或者仅仅是为了尝试一种新的、好玩的语言,那么请毫不犹豫地选择 Python 3.x 系列的最高版本(目前是 Python 3.4.3) 。1.2 为什么说 Python 采用的是基于值的内存管理模式?答:Python 采用的是基于值的内存管理方式,如果为不同变量赋值相同值,则在内存中只有一份该值,多个变量指向同一块内存地址,例如下面的代码。 x = 3 id(x)10417624 y = 3 id(y)10417624 y = 5 id(y)104176
3、00 id(x)104176241.3 在 Python 中导入模块中的对象有哪几种方式?答:常用的有三种方式,分别为 import 模块名 as 别名 from 模块名 import 对象名 as 别名 from math import *1.4 使用 pip 命令安装 numpy、scipy 模块。答:在命令提示符环境下执行下面的命令:pip install numpypip install scipy1.5 编写程序,用户输入一个三位以上的整数,输出其百位以上的数字。例如用户输入 1234,则程序输出 12。 (提示:使用整除运算。 )答:1)Python 3.4.2 代码:x = in
4、put(Please input an integer of more than 3 digits:)try:x = int(x)x = x/100if x = 0:print(You must input an integer of more than 3 digits.)else:print(x)except BaseException:print(You must input an integer.)2)Python 2.7.8 代码:import typesx = input(Please input an integer of more than 3 digits:)if type(
5、x) != types.IntType:print You must input an integer.elif len(str(x) != 4:print You must input an integer of more than 3 digits.else:print x/100第 2 章 Python 数据结构2.1 为什么应尽量从列表的尾部进行元素的增加与删除操作?答:当列表增加或删除元素时,列表对象自动进行内存扩展或收缩,从而保证元素之间没有缝隙,但这涉及到列表元素的移动,效率较低,应尽量从列表尾部进行元素的增加与删除操作以提高处理速度。2.2 编写程序,生成包含 1000 个 0
6、 到 100 之间的随机整数,并统计每个元素的出现次数。 (提示:使用集合。 )答:1)Python 3.4.2 代码import randomx = random.randint(0,100) for i in range(1000)d = set(x)for v in d:print(v, :, x.count(v)2)Python 2.7.8 代码import randomx = random.randint(0,100) for i in range(1000)d = set(x)for v in d:print v, :, x.count(v)2.3 编写程序,用户输入一个列表和 2
7、 个整数作为下标,然后输出列表中介于 2 个下标之间的元素组成的子列表。例如用户输入1,2,3,4,5,6和 2,5,程序输出3,4,5,6 。答:1)Python 3.4.2 代码x = input(Please input a list:)x = eval(x)start, end = eval(input(Please input the start position and the end position:)print(xstart:end)2)Python 2.7.8 代码x = input(Please input a list:)start, end = input(Pleas
8、e input the start position and the end position:)print xstart:end2.4 设计一个字典,并编写程序,用户输入内容作为键,然后输出字典中对应的值,如果用户输入的键不存在,则输出“您输入的键不存在!”答:1)Python 3.4.2 代码d = 1:a, 2:b, 3:c, 4:dv = input(Please input a key:)v = eval(v)print(d.get(v,您输入的的键不存在)2)Python 2.7.8 代码d = 1:a, 2:b, 3:c, 4:dv = input(Please input a
9、key:)print(d.get(v,您输入的的键不存在)2.5 编写程序,生成包含 20 个随机数的列表,然后将前 10 个元素升序排列,后 10 个元素降序排列,并输出结果。答:1)Python 3.4.2 代码import randomx = random.randint(0,100) for i in range(20)print(x)y = x0:10y.sort()x0:10 = yy = x10:20y.sort(reverse=True)x10:20 = yprint(x)2)Python 2.7.8 代码import randomx = random.randint(0,10
10、0) for i in range(20)print xy = x0:10y.sort()x0:10 = yy = x10:20y.sort(reverse=True)x10:20 = yprint x2.6 在 Python 中,字典和集合都是用一对 大括号 作为定界符,字典的每个元素有两部分组成,即 键 和 值 ,其中 键 不允许重复。2.7 假设有列表 a = name,age,sex和 b = Dong,38,Male,请使用一个语句将这两个列表的内容转换为字典,并且以列表 a 中的元素为键,以列表 b 中的元素为值,这个语句可以写为 c = dict(zip(a,b)。2.8 假设有
11、一个列表 a,现要求从列表 a 中每 3 个元素取 1 个,并且将取到的元素组成新的列表 b,可以使用语句 b = a:3。2.9 使用列表推导式生成包含 10 个数字 5 的列表,语句可以写为 5 for i in range(10)。2.10 不可以 (可以、不可以)使用 del 命令来删除元组中的部分元素。第 3 章 选择结构与循环结构3.1 分析逻辑运算符“or”的短路求值特性。答:假设有表达式“表达式 1 or 表达式 2”,如果表达式 1 的值等价于 True,那么无论表达式 2 的值是什么,整个表达式的值总是等价于 True。因此,不需要再计算表达式 2 的值。3.2 编写程序,
12、运行后用户输入 4 位整数作为年份,判断其是否为闰年。如果年份能被 400 整除,则为闰年;如果年份能被 4 整除但不能被 100 整除也为闰年。答:1)Python 3.4.2 代码x = input(Please input an integer of 4 digits meaning the year:)x = eval(x)if x%400=0 or (x%4=0 and not x%100=0):print(Yes)else:print(No)2)Python 2.7.8 代码x = input(Please input an integer of 4 digits meaning
13、the year:)if x%400=0 or (x%4=0 and not x%100=0):print Yeselse:print No3.3 编写程序,生成一个包含 50 个随机整数的列表,然后删除其中所有奇数。 (提示:从后向前删。 )答:1)Python 3.4.2 代码import randomx = random.randint(0,100) for i in range(50)print(x)i = len(x)-1while i=0:if xi%2=1:del xii-=1print(x)2)Python 2.7.8 代码把上面的代码中第三行和最后一行改为 print x 即
14、可。34 编写程序,生成一个包含 20 个随机整数的列表,然后对其中偶数下标的元素进行降序排列,奇数下标的元素不变。 (提示:使用切片。 )答:1)Python 3.4.2 代码import randomx = random.randint(0,100) for i in range(20)print(x)y = x:2y.sort(reverse=True)x:2 = yprint(x)2)Python 2.7.8 代码把上面的代码中第三行和最后一行改为 print x 即可。35 编写程序,用户从键盘输入小于 1000 的整数,对其进行因式分解。例如,10=25,60=2235。答:1)P
15、ython 3.4.2 代码x = input(Please input an integer less than 1000:)x = eval(x)t = xi = 2result = while True:if t=1:breakif t%i=0:result.append(i)t = t/ielse:i+=1Print x,=,*.join(map(str,result)2)Python 2.7.8 代码x = input(Please input an integer less than 1000:)t = xi = 2result = while True:if t=1:breaki
16、f t%i=0:result.append(i)t = t/ielse:i+=1print x,=,*.join(map(str,result)3.6 编写程序,至少使用 2 种不同的方法计算 100 以内所有奇数的和。答:Python 3.4.2 代码如下,如果使用 Python 2.7.8 只需要把其中的 print()函数改为print 语句即可。x = i for i in range(1,100) if i%2=1print(sum(x)print(sum(range(1,100):2)3.7 编写程序,实现分段函数计算,如下表所示。x yx=20:print(0)elif 0bw+
17、b)s(?P=f)matchResult = pattern.search(x)x = x.replace(matchResult.group(0),matchResult.group(1)4.4 简单解释 Python 的字符串驻留机制。答:Python 支持字符串驻留机制,即:对于短字符串,将其赋值给多个不同的对象时,内存中只有一个副本,多个对象共享该副本。这一点不适用于长字符串,即长字符串不遵守驻留机制,下面的代码演示了短字符串和长字符串在这方面的区别。 a = 1234 b = 1234 id(a) = id(b)True a = 1234*50 b = 1234*50 id(a) =
18、 id(b)False4.5 编写程序,用户输入一段英文,然后输出这段英文中所有长度为 3 个字母的单词。答:这里给出 Python 3.4.2 代码,如果使用 Python 2.7.8 的话只需要修改其中的 print()函数为 print 语句即可。import rex = input(Please input a string:)pattern = pile(rba-zA-Z3b)print(pattern.findall(x)第 5 章 函数设计与使用5.1 运行 5.3.1 小节最后的示例代码,查看结果并分析原因。答:原因是对于函数的默认值参数只会被处理一次,下次再调用函数并且不为默
19、认值参数赋值时会继续使用上一次的结果,对于列表这样的结构,如果调用函数时为默认值参数的列表插入或删除了元素,将会得到保留,从而影响下一次调用。5.2 编写函数,判断一个整数是否为素数,并编写主程序调用该函数。答:这里给出 Python 3.4.2 代码,如果使用 Python 2.7.8 的话只需要修改其中的 print()函数为 print 语句即可。import mathdef IsPrime(v):n = int(math.sqrt(v)+1)for i in range(2,n):if v%i=0:return Noelse:return Yesprint(IsPrime(37)pri
20、nt(IsPrime(60)print(IsPrime(113)5.3 编写函数,接收一个字符串,分别统计大写字母、小写字母、数字、其他字符的个数,并以元组的形式返回结果。答:这里给出 Python 3.4.2 代码,如果使用 Python 2.7.8 的话只需要修改其中的 print()函数为 print 语句即可。def demo(v):capital = little = digit = other =0for i in v:if A def demo():a=3print a a=5 demo()3 a55.5 编写函数,可以接收任意多个整数并输出其中的最大值和所有整数之和。答:这里给
21、出 Python 3.4.2 代码,如果使用 Python 2.7.8 的话只需要修改其中的 print()函数为 print 语句即可。def demo(*v):print(v)print(max(v)print(sum(v)demo(1,2,3)demo(1,2,3,4)demo(1,2,3,4,5)5.6 编写函数,模拟内置函数 sum()。答:这里给出 Python 3.4.2 代码,如果使用 Python 2.7.8 的话只需要修改其中的 print()函数为 print 语句即可。def Sum(v):s = 0for i in v:s += ireturn sx = 1,2,3,
22、4,5print(Sum(x)x = (1,2,3,4,5)print(Sum(x)5.7 编写函数,模拟内置函数 sorted()。答:这里给出 Python 3.4.2 代码,如果使用 Python 2.7.8 的话只需要修改其中的 print()函数为 print 语句即可。def Sorted(v):t = v:r = while t:tt = min(t)r.append(tt)t.remove(tt)return rx = 1,3,5,2,1,0,9,7print(x)print(Sorted(x)第 6 章 面向对象程序设计6.1 继承 6.5 节例 2 中的 Person 类生
23、成 Student 类,填写新的函数用来设置学生专业,然后生成该类对象并显示信息。答:Python 3.4.2 代码为import typesclass Person(object): #基类必须继承于 object,否则在派生类中将无法使用 super()函数def _init_(self, name = , age = 20, sex = man):self.setName(name)self.setAge(age)self.setSex(sex)def setName(self, name):if not isinstance(name,str):print(name must be s
24、tring.)returnself._name = namedef setAge(self, age):if not isinstance(age,int):print(age must be integer.)returnself._age = agedef setSex(self, sex):if sex != man and sex != woman:print(sex must be “man“ or “woman“)returnself._sex = sexdef show(self):print(self._name)print(self._age)print(self._sex)
25、class Student(Person):def _init_(self, name=, age = 30, sex = man, major = Computer):#调用基类构造方法初始化基类的私有数据成员super(Student, self)._init_(name, age, sex)self.setMajor(major) #初始化派生类的数据成员def setMajor(self, major):if not isinstance(major, str):print(major must be a string.)returnself._major = majordef sho
26、w(self):super(Student, self).show()print(self._major)if _name_ =_main_:zhangsan = Person(Zhang San, 19, man)zhangsan.show()lisi = Student(Li Si,32, man, Math)lisi.show()6.2 设计一个三维向量类,并实现向量的加法、减法以及向量与标量的乘法和除法运算。答:Python 3.4.2 代码如下class Vecter3:def _init_(self, x=0, y=0, z=0):self.X = xself.Y = yself.
27、Z = zdef _add_(self, n):r = Vecter3()r.X = self.X + n.Xr.Y = self.Y + n.Yr.Z = self.Z + n.Zreturn rdef _sub_(self, n):r = Vecter3()r.X = self.X - n.Xr.Y = self.Y - n.Yr.Z = self.Z - n.Zreturn rdef _mul_(self, n):r = Vecter3()r.X = self.X * nr.Y = self.Y * nr.Z = self.Z * nreturn rdef _truediv_(self,
28、 n):r = Vecter3()r.X = self.X / nr.Y = self.Y / nr.Z = self.Z / nreturn rdef _floordiv_(self, n):r = Vecter3()r.X = self.X / nr.Y = self.Y / nr.Z = self.Z / nreturn rdef show(self):print(self.X,self.Y,self.Z)v1 = Vecter3(1,2,3)v2 = Vecter3(4,5,6)v3 = v1+v2v3.show()v4 = v1-v2v4.show()v5 = v1*3v5.show
29、()v6 = v1/2v6.show()6.3 面向对象程序设计的三要素分别为 封装 、 继承 和 多态 。6.4 简单解释 Python 中以下划线开头的变量名特点。答:在 Python 中,以下划线开头的变量名有特殊的含义,尤其是在类的定义中。用下划线作为变量前缀和后缀来表示类的特殊成员: _xxx:这样的对象叫做保护变量,不能用from module import *导入,只有类对象和子类对象能访问这些变量; _xxx_:系统定义的特殊成员名字; _xxx:类中的私有成员,只有类对象自己能访问,子类对象也不能访问到这个成员,但在对象外部可以通过“对象名._类名_xxx”这样的特殊方式来访
30、问。Python 中没有纯粹的 C+意义上的私有成员。6.5 与运算符 “*”对应的特殊方法名为 _pow_() ,与运算符“/”对应的特殊方法名为 _floordiv_() 。第 7 章 文件操作7.1 假设有一个英文文本文件,编写程序读取其内容,并将其中的大写字母变为小写字母,小写字母变为大写字母。答:f = open(rd:1.txt,r)s = f.readlines()f.close()r = i.swapcase() for i in sf = open(rd:2.txt,w)f.writelines(r)f.close()7.2 编写程序,将包含学生成绩的字典保存为二进制文件,然
31、后再读取内容并显示。答:Python 3.4.2 代码import pickled = 张三:98,李四:90,王五:100print(d)f = open(score.dat,wb)pickle.dump(1,f)pickle.dump(d,f)f.closef = open(score.dat,rb)pickle.load(f)d = pickle.load(f)f.close()print(d)7.3 使用 shutil 模块中的 move()方法进行文件移动。答: import shutil shutil.move(rd:1.txt, re:1.txt)e:1.txt7.4 简单解释文
32、本文件与二进制文件的区别。答:(1)文本文件文本文件存储的是常规字符串,由若干文本行组成,通常每行以换行符n结尾。常规字符串是指记事本或其他文本编辑器能正常显示、编辑并且人类能够直接阅读和理解的字符串,如英文字母、汉字、数字字符串。文本文件可以使用字处理软件如 gedit、记事本进行编辑。(2)二进制文件二进制文件把对象内容以字节串(bytes)进行存储,无法用记事本或其他普通字处理软件直接进行编辑,通常也无法被人类直接阅读和理解,需要使用专门的软件进行解码后读取、显示、修改或执行。常见的如图形图像文件、音视频文件、可执行文件、资源文件、各种数据库文件、各类 office 文档等都属于二进制文
33、件。7.5 编写代码,将当前工作目录修改为“c: ”,并验证,最后将当前工作目录恢复为原来的目录。答: import os os.getcwd()C:Python34 os.chdir(rc:) os.getcwd()c: os.chdir(rc:Python34) os.getcwd()c:Python347.6 编写程序,用户输入一个目录和一个文件名,搜索该目录及其子目录中是否存在该文件。答:1)Python 3.4.2 代码import sysimport osdirectory = sys.argv1filename = sys.argv2paths = os.walk(directo
34、ry)for root,dirs,files in paths: if filename in files:print(Yes)breakelse:print(No)2)Python 2.7.8 代码import sysimport osdirectory = sys.argv1filename = sys.argv2paths = os.walk(directory)for root,dirs,files in paths: if filename in files:print Yesbreakelse:print No第 8 章 异常处理结构与程序调试8.1 Python 异常处理结构有哪
35、几种形式?答:比较常用的形式有:1)标准异常处理结构try:try 块 #被监控的语句,可能会引发异常except Exception, reason:except 块 #处理异常的代码如果需要捕获所有异常时,可以使用 BaseException,代码格式如下:try:except BaseException, e: except 块 #处理所有错误 上面的结构可以捕获所有异常,尽管这样做很安全,但是一般并不建议这样做。对于异常处理结构,一般的建议是尽量显式捕捉可能会出现的异常并且有针对性地编写代码进行处理,因为在实际应用开发中,很难使用同一段代码去处理所有类型的异常。当然,为了避免遗漏没有得
36、到处理的异常干扰程序的正常执行,在捕捉了所有可能想到的异常之后,您也可以使用异常处理结构的最后一个 except 来捕捉 BaseException。2)另外一种常用的异常处理结构是 try.except.else.语句。3)在实际开发中,同一段代码可能会抛出多个异常,需要针对不同的异常类型进行相应的处理。为了支持多个异常的捕捉和处理,Python 提供了带有多个 except 的异常处理结构,这类似于多分支选择结构,一旦某个 except 捕获了异常,则后面剩余的 except 子句将不会再执行。语法为:try:try 块 #被监控的语句except Exception1:except 块
37、1 #处理异常 1 的语句except Exception2:except 块 2 #处理异常 2 的语句4)将要捕获的异常写在一个元组中,可以使用一个 except 语句捕获多个异常,并且共用同一段异常处理代码,当然,除非确定要捕获的多个异常可以使用同一段代码来处理,并不建议这样做。5)最后一种常用的异常处理结构是 try.except.finally.结构。在该结构中,finally 子句中的内存无论是否发生异常都会执行,常用来做一些清理工作以释放 try 子句中申请的资源。语法如下:try:finally:#无论如何都会执行的代码8.2 异常和错误有什么区别?答:异常是指因为程序执行过程
38、中出错而在正常控制流以外采取的行为。严格来说,语法错误和逻辑错误不属于异常,但有些语法错误往往会导致异常,例如由于大小写拼写错误而访问不存在的对象,或者试图访问不存在的文件,等等。8.3 使用 pdb 模块进行 Python 程序调试主要有哪几种用法?答:主要有三种方式,1)在交互模式下使用 pdb 模块提供的功能可以直接调试语句块、表达式、函数等多种脚本。2)在程序中嵌入断点来实现调试功能在程序中首先导入 pdb 模块,然后使用 pdb.set_trace()在需要的位置设置断点。如果程序中存在通过该方法调用显式插入的断点,那么在命令提示符环境下执行该程序或双击执行程序时将自动打开 pdb
39、调试环境,即使该程序当前不处于调试状态。3)使用命令行调试程序在命令行提示符下执行“python m pdb 脚本文件名” ,则直接进入调试环境;当调试结束或程序正常结束以后,pdb 将重启该程序。8.4 Python 内建异常类的基类是 BaseException 。8.5 断言语句的语法为 assert 。8.6 Python 上下文管理语句是 with 。第 9 章 GUI 编程9.1 设计一个窗体,并放置一个按钮,单击按钮后弹出颜色对话框,关闭颜色对话框后提示选中的颜色。答:Python 2.7.8 代码如下,import wxclass wxGUI(wx.App):def OnIni
40、t(self):frame = wx.Frame(parent=None, title=wxGUI, size=(160,140)panel = wx.Panel(frame, -1) buttonOK = wx.Button(panel, -1, OK, pos=(0,0)self.Bind(wx.EVT_BUTTON, self.OnButtonOK, buttonOK)frame.Show()return Truedef OnButtonOK(self, event):colorDlg = wx.ColourDialog(None)colorDlg.ShowModal()color =
41、colorDlg.GetColourData().Colourwx.MessageBox(str(color)app = wxGUI()app.MainLoop()9.2 设计一个窗体,并放置一个按钮,按钮默认文本为“开始” ,单击按钮后文本变为“结束” ,再次单击后变为“开始” ,循环切换。答:Python 2.7.8 代码如下,import wxclass wxGUI(wx.App):def OnInit(self):frame = wx.Frame(parent=None, title=wxGUI, size=(160,140)panel = wx.Panel(frame, -1) se
42、lf.buttonOK = wx.Button(panel, -1, Start, pos=(0,0)self.Bind(wx.EVT_BUTTON, self.OnButtonOK, self.buttonOK)frame.Show()return Truedef OnButtonOK(self, event):text = self.buttonOK.GetLabelText()if text = Start:self.buttonOK.SetLabelText(End)elif text = End:self.buttonOK.SetLabelText(Start)app = wxGUI
43、()app.MainLoop()9.3 设计一个窗体,模拟 QQ 登录界面,当用户输入号码 123456 和密码 654321 时提示正确,否则提示错误。答:Python 2.7.8 代码如下,import wxclass wxGUI(wx.App):def OnInit(self):frame = wx.Frame(parent=None, title=Login, size=(250,150), pos=(350,350)panel = wx.Panel(frame, -1)label1 = wx.StaticText(panel, -1, UserName:, pos=(0,10), s
44、tyle=wx.ALIGN_RIGHT)label2 = wx.StaticText(panel, -1, Password:, pos=(0,30), style=wx.ALIGN_RIGHT)self.textName = wx.TextCtrl(panel, -1, pos=(70,10), size=(160,20)self.textPwd = wx.TextCtrl(panel, -1, pos=(70,30), size=(160,20),style=wx.TE_PASSWORD)buttonOK = wx.Button(panel, -1, OK, pos=(30,60)self
45、.Bind(wx.EVT_BUTTON, self.OnButtonOK, buttonOK)buttonCancel = wx.Button(panel, -1, Cancel, pos=(120,60)self.Bind(wx.EVT_BUTTON, self.OnButtonCancel, buttonCancel)buttonOK.SetDefault()frame.Show()return Truedef OnButtonOK(self, event):usrName = self.textName.GetValue()usrPwd = self.textPwd.GetValue()
46、if usrName=123456 and usrPwd=654321:wx.MessageBox(Right)else:wx.MessageBox(Wrong)def OnButtonCancel(self, event):passapp = wxGUI()app.MainLoop()第 10 章 网络程序设计10.1 简单解释 TCP 和 UDP 协议的区别。答:TCP 协议是面向连接的、具有质量保证的可靠传输协议,但开销较大;UDP 协议是尽最大能力传输的无连接协议,开销小,常用于视频在线点播(Video On Demand, VOD)之类的应用。TCP 协议和 UDP 协议并没有优劣之
47、分,仅仅是适用场合有所不同。10.2 同学之间合作编写 UDP 通信程序,分别编写发送端和接收端代码,发送端发送一个字符串“Hello world!” 。假设接收端在计算机的 5000 端口进行接收,并显示接收内容。答:首先使用 ipconfig/all 命令查看本机 IP 地址,然后分别编写下面的代码,并将其中的 IP 地址替换为相应的 IP 地址。接收端代码: import sockets=socket.socket(socket.AF_INET, socket.SOCK_DGRAM) s.bind(“, 5000) #空字符串表示本机任何可用 IP 地址data, addr=s.recv
48、from(1024) # 缓冲区大小为 1024 字节print received message:%s % data #显示接收到的内容s.close( )发送端代码:import sockets=socket.socket(socket.AF_INET, socket.SOCK_DGRAM)s.sendto(“Hello, world!“ , (“10.20.52.248“ ,5000) #假设 10.20.52.248 是接收端主机的 IP 地址s.close( )10.3 简单介绍 socket 模块中用于 TCP 编程的常用方法。TCP 一般用于要求可靠数据传输的场合。编写 TCP 程序时经常需要用到的 socket 模块方法主要有: connect(address):连接远程计算机 send(bytes,flags):发送数据 recv(bufsize