程昱
第1章基础知识
1.1简单说明如何选择正确的Python版本。答:在选择Python的时候,一定要先考虑清楚自己学习Python的目的是什么,打算做哪方面的开发,有哪些扩展库可用,这些扩展库最高支持哪个版本的Python,是Python2.x还是Python3.x,最高支持到Python2.7.6还是Python2.7.9。这些问题都确定以后,再做出自己的选择,这样才能事半功倍,而不至于把大量时间浪费在Python的反复安装和卸载上。同时还应该注意,当更新的Python版本推出之后,不要急于更新,而是应该等确定自己所必须使用的扩展库也推出了较新版本之后再进行更新。尽管如此,Python3毕竟是大势所趋,如果您暂时还没想到要做什么行业领域的应用开发,或者仅仅是为了尝试一种新的、好玩的语言,那么请毫不犹豫地选择Python3.x系列的最高版本(目前是Python3.4.3)。1.2为什么说Python采用的是基于值的内存管理模式?Python采用的是基于值的内存管理方式,如果为不同变量赋值相同值,则在内存中只有一份该值,多个变量指向同一块内存地址,例如下面的代码。>>>x=3>>>id(x)10417624>>>y=3>>>id(y)10417624>>>y=5>>>id(y)10417600>>>id(x)10417624>>>x=[1,2,3,1,1,2]>>>id(x[0])==id(x[3])==id(x[4])True1.3解释Python中的运算符“/”和“//”的区别。答:在Python2.x中,“/”为普通除法,当两个数值对象进行除法运算时,最终结果的精度与操作数中精度最高的一致;在Python3.x中,“/”为真除法,与除法的数学含义一致。在Python2.x和Python3.x中,“//”表示整除,对整数或浮点数进行该运算时,结果为数学除法的整数部分。1.4在Python中导入模块中的对象有哪几种方式?答:常用的有三种方式,分别为1.5import模块名[as别名]from模块名import对象名[as别名]frommathimport*pip是目前比较常用的Python扩展库管理工具。1.6解释Python脚本程序的“__name__”变量及其作用。答:每个Python脚本在运行时都有一个“__name__”属性。如果脚本作为模块被导入,则其“__name__”属性的值被自动设置为模块名;如果脚本独立运行,则其“__name__”属性值被自动设置为“__main__”。利用“__name__”属性即可控制Python程序的运行方式。1.7运算符“%”1.8一个数字“5”可以是(可以、不可以)对浮点数进行求余数操作。(是、不是)合法的Python表达式。界定符。确定,而在Python1.9在Python2.x中,input()函数接收到的数据类型由3.x中该函数则认为接收到的用户输入数据一律为字符串1.10编写程序,用户输入一个三位以上的整数,输出其百位以上的数字。例如用户输入1234,则程序输出12。(提示:使用整除运算。)答:1)Python3.4.2代码:x=input('Pleaseinputanintegerofmorethan3digits:')try:x=int(x)x=x//100ifx==0:print('Youmustinputanintegerofmorethan3digits.')else:print(x)exceptBaseException:print('Youmustinputaninteger.')2)Python2.7.8代码:importtypesx=input('Pleaseinputanintegerofmorethan3digits:')iftype(x)!=types.IntType:print'Youmustinputaninteger.'eliflen(str(x))!=4:print'Youmustinputanintegerofmorethan3digits.'else:printx//100第2章Python序列
2.1为什么应尽量从列表的尾部进行元素的增加与删除操作?答:当列表增加或删除元素时,列表对象自动进行内存扩展或收缩,从而保证元素之间没有缝隙,但这涉及到列表元素的移动,效率较低,应尽量从列表尾部进行元素的增加与删除操作以提高处理速度。2.2range()函数在Python2.x中返回一个函数返回一个可迭代的range对象。包含整数的列表,而Python3.x的range()2.3编写程序,生成包含1000个0到100之间的随机整数,并统计每个元素的出现次数。答:可以使用集合来实现该功能。1)Python3.4.2代码importrandomx=[random.randint(0,100)foriinrange(1000)]d=set(x)forvind:print(v,':',x.count(v))2)Python2.7.8代码importrandomx=[random.randint(0,100)foriinrange(1000)]d=set(x)forvind:printv,':',x.count(v)也可以直接使用字典来实现该功能,并且获得更高的执行效率,例如下面的Python3.4.2代码:listRandom=[random.randint(1,100)foriinrange(1000000)]d=dict()start=time.time()foriinlistRandom:#对随机数列表扫描一次,即可得到结果d[i]=d.get(i,0)+1print(time.time()-start)2.4表达式“[3]in[1,2,3,4]”的值为False。2.5编写程序,用户输入一个列表和2个整数作为下标,然后输出列表中介于2个下标之间的元素组成的子列表。例如用户输入[1,2,3,4,5,6]和2,5,程序输出[3,4,5,6]。答:1)Python3.4.2代码x=input('Pleaseinputalist:')x=eval(x)start,end=eval(input('Pleaseinputthestartpositionandtheendposition:'))print(x[start:end])2)Python2.7.8代码x=input('Pleaseinputalist:')start,end=input('Pleaseinputthestartpositionandtheendposition:')printx[start:end]2.6列表对象的sort()方法用来对列表元素进行原地排序,该函数返回值为2.7列表对象的remove()None。方法删除首次出现的指定元素,如果列表中不存在要删除的元素,则抛出异常。2.8假设列表对象aList的值为[3,4,5,6,7,9,11,13,15,17],那么切片aList[3:7]得到的值是[6,7,9,11]。2.9设计一个字典,并编写程序,用户输入内容作为“键”,然后输出字典中对应的“值”,如果用户输入的“键”不存在,则输出“您输入的键不存在!”答:1)Python3.4.2代码d={1:'a',2:'b',3:'c',4:'d'}v=input('Pleaseinputakey:')v=eval(v)print(d.get(v,'您输入的的键不存在'))2)Python2.7.8代码d={1:'a',2:'b',3:'c',4:'d'}v=input('Pleaseinputakey:')print(d.get(v,'您输入的的键不存在'))2.10编写程序,生成包含20个随机数的列表,然后将前10个元素升序排列,后10个元素降序排列,并输出结果。答:1)Python3.4.2代码importrandomx=[random.randint(0,100)foriinrange(20)]print(x)y=x[0:10]y.sort()x[0:10]=yy=x[10:20]y.sort(reverse=True)x[10:20]=yprint(x)2)Python2.7.8代码importrandomx=[random.randint(0,100)foriinrange(20)]printxy=x[0:10]y.sort()x[0:10]=yy=x[10:20]y.sort(reverse=True)x[10:20]=yprintx2.11在Python中,字典和集合都是用一对两部分组成,即“键”和“值”大括号作为界定符,字典的每个元素有不允许重复。,其中“键”2.12使用字典对象的象的keys()items()方法可以返回字典的“键-值对”列表,使用字典对values()方法可以方法可以返回字典的“键”列表,使用字典对象的返回字典的“值”列表。2.13假设有列表a=['name','age','sex']和b=['Dong',38,'Male'],请使用一个语句将这两个列表的内容转换为字典,并且以列表a中的元素为“键”,以列表b中的元素为“值”,这个语句可以写为c=dict(zip(a,b))。2.14假设有一个列表a,现要求从列表a中每3个元素取1个,并且将取到的元素组成新的列表b,可以使用语句b=a[::3]。[5foriin2.15使用列表推导式生成包含10个数字5的列表,语句可以写为range(10)]2.16。不可以(可以、不可以)使用del命令来删除元组中的部分元素。第3章选择与循环
3.1分析逻辑运算符“or”的短路求值特性。答:假设有表达式“表达式1or表达式2”,如果表达式1的值等价于True,那么无论表达式2的值是什么,整个表达式的值总是等价于True。因此,不需要再计算表达式2的值。3.2编写程序,运行后用户输入4位整数作为年份,判断其是否为闰年。如果年份能被400整除,则为闰年;如果年份能被4整除但不能被100整除也为闰年。答:1)Python3.4.2代码x=input('Pleaseinputanintegerof4digitsmeaningtheyear:')x=eval(x)ifx%400==0or(x%4==0andnotx%100==0):print('Yes')else:print('No')2)Python2.7.8代码x=input('Pleaseinputanintegerof4digitsmeaningtheyear:')ifx%400==0or(x%4==0andnotx%100==0):print'Yes'else:print'No'3.3Python提供了两种基本的循环结构:for循环和while循环。3.4编写程序,生成一个包含50个随机整数的列表,然后删除其中所有奇数。(提示:从后向前删。)答:Python3.4.2代码如下,importrandomx=[random.randint(0,100)foriinrange(50)]print(x)i=len(x)-1whilei>=0:ifx[i]%2==1:delx[i]i-=1print(x)3.5编写程序,生成一个包含20个随机整数的列表,然后对其中偶数下标的元素进行降序排列,奇数下标的元素不变。(提示:使用切片。)答:Python3.4.2代码如下,importrandomx=[random.randint(0,100)foriinrange(20)]print(x)y=x[::2]y.sort(reverse=True)x[::2]=yprint(x)3.6编写程序,用户从键盘输入小于1000的整数,对其进行因式分解。例如,10=2×5,60=2×2×3×5。答:1)Python3.4.2代码x=input('Pleaseinputanintegerlessthan1000:')x=eval(x)t=xi=2result=[]whileTrue:ift==1:breakift%i==0:result.append(i)t=t/ielse:i+=1print(x,'=','*'.join(map(str,result)))2)Python2.7.8代码x=input('Pleaseinputanintegerlessthan1000:')t=xi=2result=[]whileTrue:ift==1:breakift%i==0:result.append(i)t=t/ielse:i+=1printx,'=','*'.join(map(str,result))3.7编写程序,至少使用2种不同的方法计算100以内所有奇数的和。答:Python3.4.2代码如下,如果使用Python2.7.8只需要把其中的print()函数改为print语句即可。x=[iforiinrange(1,100)ifi%2==1]print(sum(x))print(sum(range(1,100)[::2]))3.8编写程序,输出所有由1、2、3、4这四个数字组成的素数,并且在每个素数中每个数字只使用一次。答:Python3.4.2代码如下,答:Python3.4.2代码如下,如果使用Python2.7.8只需要把其中的print()函数改为print语句即可。x=input('Pleaseinputx:')x=eval(x)ifx<0orx>=20:print(0)elif0<=x<5:print(x)elif5<=x<10:print(3*x-5)elif10<=x<20:print(0.5*x-2)3.9编写程序,实现分段函数计算,如下表所示。xx<00<=x<50xy5<=x<1010<=x<2020<=x3x-50.5x-20答:Python3.4.2代码如下,如果使用Python2.7.8只需要把其中的print()函数改为print语句即可。x=input('Pleaseinputx:')x=eval(x)ifx<0orx>=20:print(0)elif0<=x<5:print(x)elif5<=x<10:print(3*x-5)elif10<=x<20:print(0.5*x-2)第4章字符串与正则表达式
4.1假设有一段英文,其中有单独的字母“I”误写为“i”,请编写程序进行纠正。答:这里给出Python3.4.2代码,如果使用Python2.7.8的话只需要修改其中的print()函数为print语句即可。1)不使用正则表达式x=\"iamateacher,iamman,andiam38yearsold.Iamnotabusinessman.\"x=x.replace('i','I')x=x.replace('i','I')print(x)2)使用正则表达式x=\"iamateacher,iamman,andiam38yearsold.Iamnotabusinessman.\"importrepattern=re.compile(r'(?:[^\\w]|\\b)i(?:[^\\w])')whileTrue:result=pattern.search(x)ifresult:ifresult.start(0)!=0:x=x[:result.start(0)+1]+'I'+x[result.end(0)-1:]else:x=x[:result.start(0)]+'I'+x[result.end(0)-1:]else:breakprint(x)4.2假设有一段英文,其中有单词中间的字母“i”误写为“I”,请编写程序进行纠正。答:这里给出Python3.4.2代码,如果使用Python2.7.8的话只需要修改其中的print()函数为print语句即可。importrex=\"Iamateacher,Iamman,andIam38yearsold.IamnotabusInessman.\"print(x)pattern=re.compile(r'(?:[\\w])I(?:[\\w])')whileTrue:result=pattern.search(x)ifresult:ifresult.start(0)!=0:x=x[:result.start(0)+1]+'i'+x[result.end(0)-1:]else:x=x[:result.start(0)]+'i'+x[result.end(0)-1:]else:breakprint(x)4.3有一段英文文本,其中有单词连续重复了2次,编写程序检查重复的单词并只保留一个。例如文本内容为“Thisisisadesk.”,程序输出为“Thisisadesk.”答:这里给出Python3.4.2代码,如果使用Python2.7.8的话只需要修改其中的print()函数为print语句即可。1)方法一importrex='Thisisaadesk.'pattern=re.compile(r'\\b(\\w+)(\\s+\\1){1,}\\b')matchResult=pattern.search(x)x=pattern.sub(matchResult.group(1),x)print(x)2)方法二x='Thisisaadesk.'pattern=re.compile(r'(?P 5.1运行5.3.1小节最后的示例代码,查看结果并分析原因。答:原因是对于函数的默认值参数只会被处理一次,下次再调用函数并且不为默认值参数赋值时会继续使用上一次的结果,对于列表这样的结构,如果调用函数时为默认值参数的列表插入或删除了元素,将会得到保留,从而影响下一次调用。5.2编写函数,判断一个整数是否为素数,并编写主程序调用该函数。答:这里给出Python3.4.2代码,如果使用Python2.7.8的话只需要修改其中的print()函数为print语句即可。importmathdefIsPrime(v):n=int(math.sqrt(v)+1)foriinrange(2,n):ifv%i==0:return'No'else:return'Yes'print(IsPrime(37))print(IsPrime(60))print(IsPrime(113))5.3编写函数,接收一个字符串,分别统计大写字母、小写字母、数字、其他字符的个数,并以元组的形式返回结果。答:这里给出Python3.4.2代码,如果使用Python2.7.8的话只需要修改其中的print()函数为print语句即可。defdemo(v):capital=little=digit=other=0foriinv:if'A'<=i<='Z':capital+=1elif'a'<=i<='z':little+=1elif'0'<=i<='9':digit+=1else:other+=1return(capital,little,digit,other)x='capital=little=digit=other=0'print(demo(x))5.4在函数内部可以通过关键字global来定义全局变量。5.5如果函数中没有return语句或者return语句不带任何返回值,那么该函数的返回值为None。5.6调用带有默认值参数的函数时,不能为默认值参数传递任何值,必须使用函数定义时设置的默认值。(对、错)5.7在Python程序中,局部变量会隐藏同名的全局变量吗?请编写代码进行验证。答案:会。>>>defdemo():a=3printa>>>a=5>>>demo()3>>>a55.8lambda表达式只能用来创建匿名函数,不能为这样的函数起名字。(对、错)5.9编写函数,可以接收任意多个整数并输出其中的最大值和所有整数之和。答:这里给出Python3.4.2代码,如果使用Python2.7.8的话只需要修改其中的print()函数为print语句即可。defdemo(*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.10编写函数,模拟内置函数sum()。答:这里给出Python3.4.2代码,如果使用Python2.7.8的话只需要修改其中的print()函数为print语句即可。defSum(v):s=0foriinv:s+=ireturnsx=[1,2,3,4,5]print(Sum(x))x=(1,2,3,4,5)print(Sum(x))5.11包含yield语句的函数可以用来创建生成器。5.12编写函数,模拟内置函数sorted()。答:这里给出Python3.4.2代码,如果使用Python2.7.8的话只需要修改其中的print()函数为print语句即可。defSorted(v):t=v[::]r=[]whilet:tt=min(t)r.append(tt)t.remove(tt)returnrx=[1,3,5,2,1,0,9,7]print(x)print(Sorted(x))第6章面向对象程序设计 6.1继承6.5节例2中的Person类生成Student类,填写新的函数用来设置学生专业,然后生成该类对象并显示信息。答:Python3.4.2代码为importtypesclassPerson(object):#基类必须继承于object,否则在派生类中将无法使用super()函数def__init__(self,name='',age=20,sex='man'):self.setName(name)self.setAge(age)self.setSex(sex)defsetName(self,name):ifnotisinstance(name,str):print('namemustbestring.')returnself.__name=namedefsetAge(self,age):ifnotisinstance(age,int):print('agemustbeinteger.')returnself.__age=agedefsetSex(self,sex):ifsex!='man'andsex!='woman':print('sexmustbe\"man\"or\"woman\"')returnself.__sex=sexdefshow(self):print(self.__name)print(self.__age)print(self.__sex)classStudent(Person):def__init__(self,name='',age=30,sex='man',major='Computer'):#调用基类构造方法初始化基类的私有数据成员super(Student,self).__init__(name,age,sex)self.setMajor(major)#初始化派生类的数据成员defsetMajor(self,major):ifnotisinstance(major,str):print('majormustbeastring.')returnself.__major=majordefshow(self):super(Student,self).show()print(self.__major)if__name__=='__main__':zhangsan=Person('ZhangSan',19,'man')zhangsan.show()lisi=Student('LiSi',32,'man','Math')lisi.show()6.2设计一个三维向量类,并实现向量的加法、减法以及向量与标量的乘法和除法运算。答:Python3.4.2代码如下classVecter3:def__init__(self,x=0,y=0,z=0):self.X=xself.Y=yself.Z=zdef__add__(self,n):r=Vecter3()r.X=self.X+n.Xr.Y=self.Y+n.Yr.Z=self.Z+n.Zreturnrdef__sub__(self,n):r=Vecter3()r.X=self.X-n.Xr.Y=self.Y-n.Yr.Z=self.Z-n.Zreturnrdef__mul__(self,n):r=Vecter3()r.X=self.X*nr.Y=self.Y*nr.Z=self.Z*nreturnrdef__truediv__(self,n):r=Vecter3()r.X=self.X/nr.Y=self.Y/nr.Z=self.Z/nreturnrdef__floordiv__(self,n):r=Vecter3()r.X=self.X//nr.Y=self.Y//nr.Z=self.Z//nreturnrdefshow(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()v6=v1/2v6.show()6.3面向对象程序设计的三要素分别为封装、继承和多态。6.4简单解释Python中以下划线开头的变量名特点。答:在Python中,以下划线开头的变量名有特殊的含义,尤其是在类的定义中。用下划线作为变量前缀和后缀来表示类的特殊成员:_xxx:这样的对象叫做保护变量,不能用'frommoduleimport*'导入,只有类对象和子类对象能访问这些变量;__xxx__:系统定义的特殊成员名字;__xxx:类中的私有成员,只有类对象自己能访问,子类对象也不能访问到这个成员,但在对象外部可以通过“对象名._类名__xxx”这样的特殊方式来访问。Python中没有纯粹的C++意义上的私有成员。6.5与运算符“**”对应的特殊方法名为方法名为__floordiv__()。__pow__(),与运算符“//”对应的特殊6.6假设a为类A的对象且包含一个私有数据成员“__value”,那么在类的外部通过对象a直接将其私有数据成员“__value”的值设置为3的语句可以写作a._A__value。第7章文件操作 7.1假设有一个英文文本文件,编写程序读取其内容,并将其中的大写字母变为小写字母,小写字母变为大写字母。答:f=open(r'd:\\1.txt','r')s=f.readlines()f.close()r=[i.swapcase()foriins]f=open(r'd:\\2.txt','w')f.writelines(r)f.close()7.2编写程序,将包含学生成绩的字典保存为二进制文件,然后再读取内容并显示。答:Python3.4.2代码importpickled={'张三':98,'李四':90,'王五':100}print(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()方法进行文件移动。答:>>>importshutil>>>shutil.move(r'd:\\1.txt',r'e:\\1.txt')'e:\\\\1.txt'7.4简单解释文本文件与二进制文件的区别。答:(1)文本文件文本文件存储的是常规字符串,由若干文本行组成,通常每行以换行符'\\n'结尾。常规字符串是指记事本或其他文本编辑器能正常显示、编辑并且人类能够直接阅读和理解的字符串,如英文字母、汉字、数字字符串。文本文件可以使用字处理软件如gedit、记事本进行编辑。(2)二进制文件二进制文件把对象内容以字节串(bytes)进行存储,无法用记事本或其他普通字处理软件直接进行编辑,通常也无法被人类直接阅读和理解,需要使用专门的软件进行解码后读取、显示、修改或执行。常见的如图形图像文件、音视频文件、可执行文件、资源文件、各种数据库文件、各类office文档等都属于二进制文件。7.5编写代码,将当前工作目录修改为“C:\\”,并验证,最后将当前工作目录恢复为原来的目录。答:>>>importos>>>os.getcwd()'C:\\\\Python34'>>>os.chdir(r'c:\\\\')>>>os.getcwd()'c:\\\\'>>>os.chdir(r'c:\\Python34')>>>os.getcwd()'c:\\\\Python34'7.6编写程序,用户输入一个目录和一个文件名,搜索该目录及其子目录中是否存在该文件。答:1)Python3.4.2代码importsysimportosdirectory=sys.argv[1]filename=sys.argv[2]paths=os.walk(directory)forroot,dirs,filesinpaths:iffilenameinfiles:print('Yes')breakelse:print('No')2)Python2.7.8代码importsysimportosdirectory=sys.argv[1]filename=sys.argv[2]paths=os.walk(directory)forroot,dirs,filesinpaths:iffilenameinfiles:print'Yes'breakelse:print'No'7.7文件对象的flush()方法用来把缓冲区的内容写入文件,但不关闭文件。方法用来测试指定的路径是否为文件。7.8os.path模块中的7.9os模块的表。isfile()listdir()方法用来返回包含指定文件夹中所有文件和子文件夹的列第8章异常处理结构与程序调试 8.1Python异常处理结构有哪几种形式?答:比较常用的形式有:1)标准异常处理结构try:try块#被监控的语句,可能会引发异常exceptException[,reason]:except块#处理异常的代码如果需要捕获所有异常时,可以使用BaseException,代码格式如下:try:……exceptBaseException,e:except块#处理所有错误上面的结构可以捕获所有异常,尽管这样做很安全,但是一般并不建议这样做。对于异常处理结构,一般的建议是尽量显式捕捉可能会出现的异常并且有针对性地编写代码进行处理,因为在实际应用开发中,很难使用同一段代码去处理所有类型的异常。当然,为了避免遗漏没有得到处理的异常干扰程序的正常执行,在捕捉了所有可能想到的异常之后,您也可以使用异常处理结构的最后一个except来捕捉BaseException。2)另外一种常用的异常处理结构是try...except...else...语句。3)在实际开发中,同一段代码可能会抛出多个异常,需要针对不同的异常类型进行相应的处理。为了支持多个异常的捕捉和处理,Python提供了带有多个except的异常处理结构,这类似于多分支选择结构,一旦某个except捕获了异常,则后面剩余的except子句将不会再执行。语法为:try:try块exceptException1:except块1exceptException2:except块2#被监控的语句#处理异常1的语句#处理异常2的语句4)将要捕获的异常写在一个元组中,可以使用一个except语句捕获多个异常,并且共用同一段异常处理代码,当然,除非确定要捕获的多个异常可以使用同一段代码来处理,并不建议这样做。5)最后一种常用的异常处理结构是try...except...finally...结构。在该结构中,finally子句中的内存无论是否发生异常都会执行,常用来做一些清理工作以释放try子句中申请的资源。语法如下:try:……finally:......#无论如何都会执行的代码8.2异常和错误有什么区别?答:异常是指因为程序执行过程中出错而在正常控制流以外采取的行为。严格来说,语法错误和逻辑错误不属于异常,但有些语法错误往往会导致异常,例如由于大小写拼写错误而访问不存在的对象,或者试图访问不存在的文件,等等。8.3使用pdb模块进行Python程序调试主要有哪几种用法?答:主要有三种方式,1)在交互模式下使用pdb模块提供的功能可以直接调试语句块、表达式、函数等多种脚本。2)在程序中嵌入断点来实现调试功能在程序中首先导入pdb模块,然后使用pdb.set_trace()在需要的位置设置断点。如果程序中存在通过该方法调用显式插入的断点,那么在命令提示符环境下执行该程序或双击执行程序时将自动打开pdb调试环境,即使该程序当前不处于调试状态。3)使用命令行调试程序在命令行提示符下执行“python–mpdb脚本文件名”,则直接进入调试环境;当调试结束或程序正常结束以后,pdb将重启该程序。8.4Python内建异常类的基类是8.5断言语句的语法为assertBaseException。with。。8.6Python上下文管理语句是第9章GUI编程 9.1设计一个窗体,并放置一个按钮,单击按钮后弹出颜色对话框,关闭颜色对话框后提示选中的颜色。答:Python2.7.8代码如下,importwxclasswxGUI(wx.App):defOnInit(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()returnTruedefOnButtonOK(self,event):colorDlg=wx.ColourDialog(None)colorDlg.ShowModal()color=colorDlg.GetColourData().Colourwx.MessageBox(str(color))app=wxGUI()app.MainLoop()9.2设计一个窗体,并放置一个按钮,按钮默认文本为“开始”,单击按钮后文本变为“结束”,再次单击后变为“开始”,循环切换。答:Python2.7.8代码如下,importwxclasswxGUI(wx.App):defOnInit(self):frame=wx.Frame(parent=None,title='wxGUI',size=(160,140))panel=wx.Panel(frame,-1)self.buttonOK=wx.Button(panel,-1,'Start',pos=(0,0))self.Bind(wx.EVT_BUTTON,self.OnButtonOK,self.buttonOK)frame.Show()returnTruedefOnButtonOK(self,event):text=self.buttonOK.GetLabelText()iftext=='Start':self.buttonOK.SetLabelText('End')eliftext=='End':self.buttonOK.SetLabelText('Start')app=wxGUI()app.MainLoop()9.3设计一个窗体,模拟QQ登录界面,当用户输入号码123456和密码654321时提示正确,否则提示错误。答:Python2.7.8代码如下,importwxclasswxGUI(wx.App):defOnInit(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),style=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,size=(160,20),style=wx.TE_PASSWORD)buttonOK=wx.Button(panel,-1,'OK',pos=(30,60))self.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()returnTruedefOnButtonOK(self,event):usrName=self.textName.GetValue()usrPwd=self.textPwd.GetValue()ifusrName=='123456'andusrPwd=='654321':wx.MessageBox('Right')else:wx.MessageBox('Wrong')defOnButtonCancel(self,event):passapp=wxGUI()app.MainLoop()pos=(70,30), 因篇幅问题不能全部显示,请点此查看更多更全内容