《Python程序设计》习题与答案

上传人:无*** 文档编号:56032124 上传时间:2022-02-19 格式:DOCX 页数:52 大小:191.36KB
收藏 版权申诉 举报 下载
《Python程序设计》习题与答案_第1页
第1页 / 共52页
《Python程序设计》习题与答案_第2页
第2页 / 共52页
《Python程序设计》习题与答案_第3页
第3页 / 共52页
资源描述:

《《Python程序设计》习题与答案》由会员分享,可在线阅读,更多相关《《Python程序设计》习题与答案(52页珍藏版)》请在装配图网上搜索。

1、Python程序设计习题与参考答案第1章基础知识1.1 简单说明如何选择正确的Python版本。答:在选择Python的时候,一定要先考虑清楚自己学习Python的目的是什么,打算做哪方面的开发,有哪些扩展库可用,这些扩展库最高反复安装和卸载上。同时还应该注意,当更新的Python版本推出之后,不要急于更新,而是应该等确定自己所必须使用的扩展库也推出了较新版本之后再进行更新。尽管如此,Python3毕竟是大势所趋,如果您暂时还没想到要做什么行业领域的应用开发,或者仅仅是为了尝试一种新的、好玩的语言,那么请毫不犹豫地选择Python3.x系列的最高版本(目前是Python3.4.3)。1.2 为

2、什么说Python采用的是基于值的内存管理模式?答:Python采用的是基于值的内存管理方式,如果为不同变量赋值相同值,则在内存中只有一份该值,多个变量指向同一块内存地址,例如下面的代码。 x=3id(x) y=3 id(y) y=5 id(y)1.3 在Python中导入模块中的对象有哪几种方式?答:常用的有三种方式,分别为import模块名as别名from模块名import对象名as别名frommathimport*1.4 使用pip命令安装numpyscipy模块。答:在命令提示符环境下执行下面的命令:pipinstallnumpypipinstallscipy1.5 编写程序,用户输入

3、一个三位以上的整数,输出其百位以上的数字。例如用户输入1234,则程序输出12。(提示:使用整除运算。)答:x=input(Pleaseinputanintegerofmorethan3digits:)try:x=int(x)x=x/100ifx=0:print(Youmustinputanintegerofmorethan3digits.)else:print(x)exceptBaseException:print(Youmustinputaninteger.)importtypesx=input(Pleaseinputanintegerofmorethan3digits:)iftype(x

4、)!=types.IntType:printYoumustinputaninteger.eliflen(str(x)!=4:printYoumustinputanintegerofmorethan3digits.else:printx/100第2章Python数据结构2.1 为什么应尽量从列表的尾部进行元素的增加与删除操作?答:当列表增加或删除元素时,列表对象自动进行内存扩展或收缩,从而保证元素之间没有缝隙,但这涉及到列表元素的移动,效率较低,应尽量从列表尾部进行元素的增加与删除操作以提高处理速度。2.2 编写程序,生成包含1000个0到100之间的随机整数,并统计每个元素的出现次数。(提示:

5、使用集合。)答:importrandomx=random.randint(0,100)foriinrange(1000)d=set(x)forvind:print(v,:,x.count(v)importrandomx=random.randint(0,100)foriinrange(1000)d=set(x)forvind:printv,:,x.count(v)2.3 编写程序,用户输入一个列表和2个整数作为下标,然后输出列表中介于2个下标之间的元素组成的子列表。例如用户输入1,2,3,4,5,6和2,5,程序输出3,4,5,6。答:x=input(Pleaseinputalist:)x=e

6、val(x)start,end=eval(input(Pleaseinputthestartpositionandtheendposition:)print(xstart:end)x=input(Pleaseinputalist:)start,end=input(Pleaseinputthestartpositionandtheendposition:)printxstart:end2.4 设计一个字典,并编写程序,用户输入内容作为键,然后输出字典中对应的值,如果用户输入的键不存在,则输出“您输入的键不存在!”答:d=1:a,2:b,3:c,4:dv=input(Pleaseinputakey

7、:)print(d.get(v,您输入的的键不存在)d=1:a,2:b,3:c,4:dv=input(Pleaseinputakey:)print(d.get(v,您输入的的键不存在)2.5 编写程序,生成包含20个随机数的列表,然后将前10个元素升序排列,后10个元素降序排列,并输出结果。答:importrandomx=random.randint(0,100)foriinrange(20)print(x)y=x0:10y.sort()x0:10=yy=x10:20y.sort(reverse=True)x10:20=yprint(x)importrandomx=random.randint

8、(0,100)foriinrange(20)printxy=x0:10y.sort()x0:10 = yy=x10:20y.sort(reverse=True)x10:20=yprintx2.6 在Python中,字典和集合都是用一对大括号作为定界符,字典的每个元素有两部分组成,即键和值,其中键不允许重复。2.7 假设有列表a=name,age,sex和b=Dong,38,Male,请使用一个语句将这两个列表的内容转换为字典,并且以列表a中的元素为键,以列表b中的元素为值,这个语句可以写为c=dict(zip(a,b)。2.8 假设有一个列表a,现要求从列表a中每3个元素取1个,并且将取到的元

9、素组成新的列表b,可以使用语句b=a:3o2.9 使用列表推导式生成包含10个数字5的列表,语句可以写为5foEinrange(10)。2.10不可以(可以、不可以)使用del命令来删除元组中的部分元素。第3章选择结构与循环结构3.1 分析逻辑运算符“or”的短路求值特性。答:假设有表达式“表达式1or表达式2,如果表达式1的值等价于True,那么无论表达式2的值是什么,整个表达式的值总是等价于True。因此,不需要再计算表达式2的值。3.2 编写程序,运行后用户输入4位整数作为年份,判断其是否为闰年。如果年份能被400整除,则为闰年;如果年份能被4整除但不能被100整除也为闰年。答:x=in

10、put(Pleaseinputanintegerof4digitsmeaningtheyear:)x=eval(x)ifx%400=0or(x%4=0andnotx%100=0):print(Yes)else:print(No)x=input(Pleaseinputanintegerof4digitsmeaningtheyear:)ifx%400=0or(x%4=0andnotx%100=0):printYeselse:printNo3.3 编写程序,生成一个包含50个随机整数的列表,然后删除其中所有奇数。(提示:从后向前删。)答:importrandomx=random.randint(0,

11、100)foriinrange(50)print(x)i=len(x)-1whilei=0:ifxi%2=1:delxii-=1print(x)把上面的代码中第三行和最后一行改为print x 即可。34编写程序,生成一个包含20个随机整数的列表,然后对其中偶数下标的元素进行降序排列,奇数下标的元素不变。(提示:使用切片。)答:importrandomx=random.randint(0,100)foriinrange(20)print(x)y=x:2y.sort(reverse=True)x:2=yprint(x)把上面的代码中第三行和最后一行改为printx即可。35编写程序,用户从键盘输

12、入小于1000的整数,对其进行因式分解。例如,10=2X5,60=2X2X3X5。答:x=input(Pleaseinputanintegerlessthan1000:)x=eval(x)t=xi=2result=whileTrue:ift=1:breakift%i=0:result.append(i)t=t/ielse:i+=1Printx,=,*.join(map(str,result)x=input(Pleaseinputanintegerlessthan1000:)t=xi=2result=whileTrue:ift=1:breakift%i=0:result.append(i)t=t

13、/ielse:i+=1printx,=,*.join(map(str,result)3.6编写程序,至少使用2种不同的方法计算100以内所有奇数的和x=iforiinrange(1,100)ifi%2=1print(sum(x)print(sum(range(1,100):2)3.7编写程序,实现分段函数计算,如下表所示xyx000=x5x5=x103x-510=x200.5x-220=x0x=input(Pleaseinputx:)x=eval(x)ifx=20:print(0)elif0=x5:print(x)elif5=x10:print(3*x-5)elif10=x20:print(0

14、.5*x-2)第4章字符串与正则表达式4.1 假设有一段英文,其中有单独的字母“I”误写为“i”,请编写程序进行纠正。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=pile(r(?:Aw|b)i(?:Aw)whileTrue:result=pattern.search

15、(x)ifresult:ifresult.start(O)!=0:x=x:result.start(0)+1+T+xresult.end(0)-1:else:x=x:result.start(0)+T+xresult.end(0)-1:else:breakprint(x)4.2 假设有一段英文,其中有单词中间的字母“i”误写为“I”,请编写程序进行纠正importrex=Iamateacher,Iamman,andIam38yearsold.Iamnotabusinessman.print(x)pattern=pile(r(?:w)I(?:w)whileTrue:result=pattern.

16、search(x)ifresult:ifresult.start(O)!=0:x=x:result.start(0)+1+i+xresult.end(0)-1:else:x=x:result.start(0)+i+xresult.end(0)-1:else:breakprint(x)4.3 有一段英文文本,其中有单词连续重复了2次,编写程序检查重复的单词并只保留一个。例如文本内容为“Thisisisadesk.,程序输出为“Thisisadesk.”1)方法一importrex=Thisisaadesk.pattern=pile(rb(w+)(s+1)1,b)matchResult=patte

17、rn.search(x)x=pattern.sub(matchResult.group(1),x)print(x)2)方法二x=Thisisaadesk.pattern=pile(r(?Pbw+b)s(?P=f)matchResult=pattern.search(x)x=x.replace(matchResult.group(0),matchResult.group(1)4.4 简单解释Python的字符串驻留机制。答:Python支持字符串驻留机制,即:对于短字符串,将其赋值给多个不同的对象时,内存中只有一个副本,多个对象共享该副本。这一点不适用于长字符串,即长字符串不遵守驻留机制,下面的

18、代码演示了短字符串和长字符串在这方面的区别。a=1234b=1234id(a)=id(b)Truea=1234*50b=1234*50id(a)=id(b)False4.5 编写程序,用户输入一段英文,然后输出这段英文中所有长度为3个字母的单词importrex=input(Pleaseinputastring:)pattern=pile(rba-zA-Z3b)print(pattern.findall(x)第5章函数设计与使用答:原因是对于函数的默认值参数只会被处理一次,下次再调用函数并且不为默认值参数赋值时会继续使用上一次的结果,对于列表这样的结构,如果调用函数时为默认值参数的列表插入或删

19、除了元素,将会得到保留,从而影响下一次调用。5.2 编写函数,判断一个整数是否为素数,并编写主程序调用该函数。importmathdefIsPrime(v):n=int(math.sqrt(v)+1)foriinrange(2,n):ifv%i=0:returnNoelse:returnYesprint(IsPrime(37)print(IsPrime(60)print(IsPrime(113)5.3 编写函数,接收一个字符串,分别统计大写字母、小写字母、数字、其他字符的个数,并以元组的形式返回结果。defdemo(v):capital=little=digit=other=0foriinv:

20、ifAv=iv=Z:capital+=1elifa=i=z:little+=1elif0=idefdemo():a=3printaa=5demo()3a55.5 编写函数,可以接收任意多个整数并输出其中的最大值和所有整数之和。defdemo(*v):print(v)print(sum(v)demo(1,2,3)demo(1,2,3,4)demo(1,2,3,4,5)5.6 编写函数,模拟内置函数defSum(v):s=0foriinv:s+=ireturnsx=1,2,3,4,5print(Sum(x)x=(1,2,3,4,5)print(Sum(x)5.7编写函数,模拟内置函数defSort

21、ed(v):t=v仁r=口whilet:tt=min(t)r.append(tt)t.remove(tt)sum() osorted。returnrx=1,3,5,2,1,0,9,7print(x)print(Sorted(x)第6章面向对象程序设计6.1 继承6.5节例2中的Person类生成Student类,填写新的函数用来设置学生专业,然后生成该类对象并显示信息。importtypesclassPerson(object):#基类必须继承于object,否则在派生类中将无法使用super()函数def_init_(self,name=,age=20,sex=man):self.setNa

22、me(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!=manandsex!=woman:print(sexmustbemanorwoman)returnsel

23、f._sex=sexdefshow(self):print(self._name)print(self._age)print(self._sex)classStudent(Person):def_init_(self,name=,age=30,sex=man,major=Computer):1.1 调用基类构造方法初始化基类的私有数据成员super(Student,self)._init_(name,age,sex)self.setMajor(major)#初始化派生类的数据成员defsetMajor(self,major):ifnotisinstance(major,str):print(m

24、ajormustbeastring.)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()1.2 设计一个三维向量类,并实现向量的加法、减法以及向量与标量的乘法和除法运微畀0classVecter3:def_init_(self,x=0,y=0,z=0):self.X=xself.

25、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

26、.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()1.3 面向对象程序设计的三要素分别为封装、继承和多态。1.4 简单解释Python中以下划线开头的变量名特点。答:在Python中,以下划线开

27、头的变量名有特殊的含义,尤其是在类的定义中。用下划线作为变量前缀和后缀来表示类的特殊成员:_xxx:这样的对象叫做保护变量,不能用frommoduleimport*导入,只有类对象和子类对象能访问这些变量;_xxx_:系统定义的特殊成员名字;_xxx:类中的私有成员,只有类对象自己能访问,子类对象也不能访问到这个成员,但在对象外部可以通过“对象名._类名xxx”这样的特殊方式来访问。Python中没有纯粹的C+馈义上的私有成员。1.5 与运算符“*”对应的特殊方法名为_pow_(),与运算符“”对应的特殊方法名为floordiv()第7章文件操作7.1 假设有一个英文文本文件,编写程序读取其内

28、容,并将其中的大写字母变为小写字母,小写字母变为大写字母。答:f=open(rd:1.txt,r)s=f.readlines()f.close()r=i.swapcase()foriinsf=open(rd:2.txt,w)f.writelines(r)f.close()7.2 编写程序,将包含学生成绩的字典保存为二进制文件,然后再读取内容并显示。importpickled=张三:98,李四:90,王五:100print(d)f=open(score.dat,wb)pickle.dump(1,f)pickle.dump(d,f)f.closef=open(score.dat,rb)pickle

29、.loadd=pickle.loadf.close()print(d)7.3 使用shutil模块中的move()方法进行文件移动。答:importshutilshutil.move(rd:1.txt,re:1.txt)e:1.txt7.4 简单解释文本文件与二进制文件的区别。答:(1)文本文件文本文件存储的是常规字符串,由若干文本行组成,通常每行以换行符n结尾。常规字符串是指记事本或其他文本编辑器能正常显示、编辑并且人类能够直接阅读和理解的字符串,如英文字母、汉字、数字字符串。文本文件可以使用字处理软件如gedit、记事本进行编辑。(2)二进制文件二进制文件把对象内容以字节串(bytes)进

30、行存储,无法用记事本或其他普通字处理软件直接进行编辑,通常也无法被人类直接阅读和理解,需要使用专门的软件进行解码后读取、显示、修改或执行。常见的如图形图像文件、音视频文件、可执行文件、资源文件、各种数据库文件、各类office文档等都属于二进制文件。7.5 编写代码,将当前工作目录修改为“工并验证,最后将当前工作目录恢复为原来的目录。答:importosos.getcwd()C:Python34os.chdir(rc:)os.getcwd()c:os.chdir(rc:Python34)os.getcwd()c:Python347.6 编写程序,用户输入一个目录和一个文件名,搜索该目录及其子目

31、录中是否存在该文件。答:importsysimportosdirectory=sys.argv1filename=sys.argv2paths=os.walk(directory)forroot,dirs,filesinpaths:iffilenameinfiles:print(Yes)breakelse:print(No)importsysimportosdirectory=sys.argv1filename=sys.argv2paths=os.walk(directory)forroot,dirs,filesinpaths:iffilenameinfiles:printYesbreakel

32、se:printNo第8章异常处理结构与程序调试8.1 Python异常处理结构有哪几种形式?答:比较常用的形式有:1)标准异常处理结构try:try块#被监控的语句,可能会引发异常exceptExceptionreason:except块#处理异常的代码如果需要捕获所有异常时,可以使用BaseException,代码格式如下:try:exceptBaseException,e:except块#处理所有错误上面的结构可以捕获所有异常,尽管这样做很安全,但是一般并不建议这样做。对于异常处理结构,一般的建议是尽量显式捕捉可能会出现的异常并且有针对性地编写代码进行处理,因为在实际应用开发中,很难使用

33、同一段代码去处理所有类型的异常。当然,为了避免遗漏没有得到处理的异常干扰程序的正常执行,在捕捉了所有可能想到的异常之后,您也可以使用异常处理结构的最后一个except来捕捉BaseException。2)另外一种常用的异常处理结构是tryexceptelse语句。3)在实际开发中,同一段代码可能会抛出多个异常,需要针对不同的异常类型进行相应的处理。为了支持多个异常的捕捉和处理,Python提供了带有多个except的异常处理结构,这类似于多分支选择结构,一旦某个except捕获了异常,则后面剩余的except子句将不会再执行。语法为:try:try块腕监控的语句exceptExceptionl

34、:except块1#处理异常1的语句exceptException2:except块2#处理异常2的语句4)将要捕获的异常写在一个元组中,可以使用一个except语句捕获多个异常,并且共用同一段异常处理代码,当然,除非确定要捕获的多个异常可以使用同一段代码来处理,并不建议这样做。5)最后一种常用的异常处理结构是tryexceptfinally结构。在该结构中,finally子句中的内存无论是否发生异常都会执行,常用来做一些清理工作以释放try子句中申请的资源。语法如下:try:finally:#无论如何都会执行的代码8.2 异常和错误有什么区别?答:异常是指因为程序执行过程中出错而在正常控制流

35、以外采取的行为。严格来说,语法错误和逻辑错误不属于异常,但有些语法错误往往会导致异常,例如由于大小写拼写错误而访问不存在的对象,或者试图访问不存在的文件,等等。8.3 使用pdb模块进行Python程序调试主要有哪几种用法?答:主要有三种方式,1)在交互模式下使用pdb模块提供的功能可以直接调试语句块、表达式、函数等多种脚本。2)在程序中嵌入断点来实现调试功能在程序中首先导入pdb模块,然后使用pdb.set_trace()在需要的位置设置断点。如果程序中存在通过该方法调用显式插入的断点,那么在命令提示符环境下执行该程序或双击执行程序时将自动打开pdb调试环境,即使该程序当前不处于调试状态。3

36、)使用命令行调试程序在命令行提示符下执行“python-mpdb脚本文件名”,则直接进入调试环境;当调试结束或程序正常结束以后,pdb将重启该程序。8.4 Python内建异常类的基类是BaseException。8.5 断言语句的语法为assert。8.6 Python上下文管理语句是with。第9章GUI编程9.1 设计一个窗体,并放置一个按钮,单击按钮后弹出颜色对话框,关闭颜色对话框后提示选中的颜色。importwxclasswxGUI(wx.App):defOnlnit(self):frame=wx.Frame(parent=None,title=wxGUI,size=(160,140

37、)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.

38、2 设计一个窗体,并放置一个按钮,按钮默认文本为“开始”,单击按钮后文本变为“结束”,再次单击后变为“开始”,循环切换。importwxclasswxGUI(wx.App):defOnlnit(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()return

39、TruedefOnButtonOK(self,event):iftext=Start:eliftext=End:app=wxGUI()app.MainLoop()9.3 设计一个窗体,模拟QQ登录界面,当用户输入号码123456和密码654321时提示正确,否则提示错误。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,

40、UserName:,pos=(0,10),style=wx.ALIGN_RIGHT)label2wx.StaticText(panel,-1, Password:,pos=(0,30),style=wx.ALIGN_RIGHT)self.textName=wx.TextCtrl(panel,-1,pos=(70,10),size=(160,20)pos=(70,30),self.textPwd=wx.TextCtrl(panel,-1,size=(160,20),style=wx.TE_PASSWORD)buttonOK=wx.Button(panel,-1,OK,pos=(30,60)sel

41、f.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):ifusrName=123456andusrPwd=654321:wx.MessageBox(Right)else:wx.MessageBox(Wrong

42、)defOnButtonCancel(self,event):passapp=wxGUI()app.MainLoop()第10章网络程序设计10.1 简单解释TC可口UDPW议的区别。答:TCPW议是面向连接的、具有质量保证的可靠传输协议,但开销较大;UD的议是尽最大能力传输的无连接协议,开销小,常用于视频在线点播(VideoOnDemand,VOD)之类的应用。TCPW议和UD的议并没有优劣之分,仅仅是适用场合有所不同。10.2 同学之间合作编写UDP1信程序,分别编写发送端和接收端代码,发送端发送一个字符串“Helloworld!假设接收端在计算机的5000端口进行接收,并显示接收内容。答

43、:首先使用ipconfig/all命令查看本机IP地址,然后分别编写下面的代码,并将其中的IP地址替换为相应的IP地址。接收端代码:importsockets=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)s.bind(,5000)#空字符串表示本机任何可用IP地址data,addr=s.recvfrom(1024)#缓冲区大小为1024字节printreceivedmessage:%s%data#显示接收至U的内容s.close()发送端代码:importsockets=socket.socket(socket.AF_INET,socket.S

44、OCK_DGRAM)0主机的IP地址s.close()10.3 简单介绍socket模块中用于TC躅程的常用方法。TCL般用于要求可靠数据传输的场合。编写TCP程序时经常需要用到的socket模块方法主要有:connect(address):连接远程计算机send(bytes,flags):发送数据recv(bufsize,flags):接收数据bind(address):绑定地址listen(backlog):开始监听,等待客户端连接accept。:响应客户端的请求10.4 编写代码读取搜狐网页首页内容。答:importurllib.requestdir(urllib.request)dir

45、(fp)print(fp.read(100)fp.close()10.5 在自己的机器上配置IIS以支持Python脚本的运行,然后使用Python编写脚本,运行后在网页上显示“Helloworld!答:核心代码为printprintStatus:200OKprintContent-type:text/htmlprintprintPythonSampleCGIprintprintThisisaheaderprintHelloworld!printprint第11章大数据处理11.1 简单介绍常见的大数据处理框架。答:主要有三种,MapReduce分布式计算框架,可以将单个大型计算作业分配给多台

46、计算机执行,可以在短时间内完成大量工作,尤其适合数值型和标称型数据,但需要对行业领域具有一定理解后重写算法来完成特定的业务处理要求。MapReduce的名字由函数式编程中常用的map和reduce两个单词组成。MapReduce在大量节点组成的集群上运行,工作流程是:单个作业被分成很多小份,输入数据也被切片并分发到每个节点,每个节点只在本地数据上做运算,对应的运算代码称为mapper,这个过程即map阶段;每个mapper的输出通过某种方式组合,根据需要可能再进行重新排序,排序后的结果再被切分成小份并分发到各个节点进行下一步处理,这个过程被称为reduce阶段,对应的代码称为reducer。不

47、同类型的作业可能需要不同数量的reducer,并且,在任何时候,每个mapper或reducer之间都不进行通信,每个节点只负责处理自己的事务,并且只在分配到本地的数据集上进行运算。Hadoop:Hadoop是MapReduce框架的一个免费开源实现,采用Java语言编写,支持在大量机器上分布式处理数据。除了分布式计算之外,Hadoop还自带分布式文件系统,可以在上面运行多种不同语言编写的分布式程序。Hadoop在可伸缩性、健壮性、计算性能和成本上具有无可替代的优势,事实上已成为当前互联网企业主流的大数据分析平台。Spark:Spark是一个针对超大数据集合的低延迟集群分布式计算系统,比Map

48、Reduce快40倍左右。Spark是Hadoop的升级版本,兼容Hadoop的API,能够读写Hadoop的HDFSHBASE顶序文件等,与之不同的是将结果保存在内存中。Hadoop作为第一代产品使用了HDFS第二代加入了Cache来保存中间计算结果,第三代则是Spark倡导的流技术Streaming。11.2 运行本章中代码并理解MapReduc编程思路答:略第12章Windows系统编程12.1 查阅相关资料,解释注册表几大根键的用途。答:略12.2 选择一个编写好的Python程序,将其转换为exe可执行文件。答:略,请参考书中相关介绍。12.3 编写代码,使用至少3中不同的方法启动W

49、indows自带的计算器程序。答:第一种方法: importosos.system(calc.exe)第二种方法: importosos.popen(calc.exe)第三种方法: importosos.startfile(calc.exe)第四种方法: importwin32apiwin32api.ShellExecute(0,open,calc.exe,“,1)第五种方法:第13章多线程编程importwin32processhandle=win32process.CreateProcess(rc:windowssystem32calc.exe,,None,None,0,win32proc

50、ess.CREATE_NO_WINDOW,None,None,win32process.STARTUPINFO()12.4编写代码,检测您所使用的操作系统版本。答:略,请参考12.5节。13.1 简单叙述创建线程的方法。答:Thread类支持使用两种方法来创建线程,一种是为构造函数传递一个可调用对象,另一种是继承Thread类并在派生类中重写_init_()和run()方法。创建了线程对象以后,可以调用其start()方法来启动,该方法自动调用该类对象的run()方法,此时该线程处于alive状态,直至线程的run()方法运行结束。13.2 简单叙述Thread对象的方法。答:(1) join

51、(timeout:阻塞当前线程,等待被调线程结束或超时后再继续执行当前线程的后续代码,参数timeout用来指定最长等待时间,单位为秒。(2) isAlive():测试线程是否处于运行状态(3) start():自动调用run()方法,启动线程,执行线程代码。(4) run():线程代码,用来实现线程的功能与业务逻辑,可以在子类中重写该方法来自定义线程的行为。13.3 简单叙述线程对象的daemon属性的作用和影响。答:在脚本运行过程中有一个主线程,若在主线程中创建了子线程,当主线程结束时根据子线程daemon属性值的不同可能会发生下面的两种情况之一:1)当某子线程的daemon属性为Fals

52、e时,主线程结束时会检测该子线程是否结束,如果该子线程尚未完成,则主线程会等待它完成后再退出;2)当某子线程的daemon属性为True时,主线程运行结束时不对该子线程进行检查而直接退出,同时所有daemon值为True的子线程将随主线程一起结束,而不论是否运行完成。daemon属性的值默认为False,如果需要修改,则必须在调用start()方法启动线程之前进行修改。13.4 解释至少3种线程同步方法。答:(1)使用Condition对象可以在某些事件触发后才处理数据,可以用于不同线程之间的通信或通知,以实现更高级别的同步。Condition对象除了具有acquire。和release。方法

53、之外,还有wait()、notify。、notify_all()等方法。下面通过经典生产者/消费者问题来演示Condition对象的用法。(2) Queue模块(在Python3中为queue模块)实现了多生产者/多消费者队列,尤其适合需要在多个线程之间进行信息交换的场合,该模块的Queue对象实现了多线程编程所需要的所有锁语义。(3) Event对象是一种简单的线程通信技术,一个线程设置Event对象,另一个线程等待Event对象。Event对象的set()方法可以设置Event对象内部的信号标志为真;clear()方法可以清除Event对象内部的信号标志,将其设置为假;isSet()方法用

54、来判断其内部信Event号标志的状态;wait()方法只有在其内部信号状态为真时将很快地执行并返回,若对象的内部信号标志为假,wait()方法将一直等待至超时或内部信号状态为真。(3)操作记录集3.1 1简单介绍SQLite数据库。答:SQLite是内嵌在Python中的轻量级、基于磁盘文件的数据库管理系统,不需要服务器进程,支持使用SQL语句来访问数据库。该数据库使用C语言开发,支持大多数SQL91标准,支持原子的、一致的、独立的和持久的事务,不支持外键限制;通过数据库级的独占性和共享锁定来实现独立事务,当多个线程同时访问同一个数据库并试图写入数据时,每一时刻只有一个线程可以写入数据。SQL

55、ite支持2TB大小的单个数据库,每个数据库完全存储在单个磁盘文件中,以B+树数据结构的形式存储,一个数据库就是一个文件,通过简单复制即可实现数据库的备份。3.2 2使用Python内置函数dir()查看Cursor对象中的方法,并使用内置函数help()查看其用法。答:略。3.3 3叙述使用Python操作Access数据库的步骤。答:(1)建立数据库连接importwin32com.clientconn.Open(DSN)(2)打开记录集rs_name=MyRecordset#表名rs.Open(+rs_name+,conn,1,3)rs.AddNew()rs.Update()(4)操作数

56、据sql_statement=InsertINTOTable_Name(Field_1,Field_2)VALUEdatal,data2)conn.Open(DSN)conn.Execute(sql_statement)conn.Close()(5)遍历记录rs.MoveFirst()count=0while1:ifrs.EOF:breakelse:count=count+1rs.MoveNext()3.4 4叙述使用Python操作MSSQLServer数据库的步骤。答:可以使用pywin32和pymssql两种不同的方式来访问MSSQLServer数据库。先来了解一下pywin32模块访问

57、MSSQLServer数据库的步骤。(1)添加引用:importadodbapiimportadodbapi.ado_constsasadc(2)创建连接:Cfg=constr=产Provider=SQLOLEDB.1;InitialCatalog=%s;DataSource=%s;userID=%s;Password=%s;%(Cfgdb,Cfgserve门,sa,Cfgpassword)conn=adodbapi.connect(constr)(3)执行sql语句:cur=conn.cursor()sql=select*fromsoftextBookwheretitle=0andremark3!=1.format(bookName,flag)cur.execute(sql)data=cur.fetchall()cur.close()(4)执行存储过程:#假设proName有三个参数,最后一个参数传了nullret=cur.callproc(procName,(parm1,parm2,None)mit()(5)关闭连接conn.close()接下来再通过一个示例来简单了解一下使用pymssql

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

  • 社区康复工作方法与内容
  • 眼睑基底细胞癌
  • 真叫卢俊分享地下车库设计
  • 省网上政务大厅便民服务事项梳理培训材料课件
  • 美丽的芦苇画真绝典藏美图
  • 相对论动力学(清华)
  • 图书馆数字资源的长期保存策略研究
  • 国际货代风险控制与事故处理
  • 战略计划与市场营销管理
  • 国际结算融资
  • 国际结算汇出汇款培训材料(PPT31页)
  • 第七课再塑生命的
  • 简易万用表设计
  • 定义任何原因引起的肠内容物不能正常运行,顺利通过肠道,称肠梗阻
  • 完美直销员应具备的素质魏驾雾
点击下载此资源

相关资源

更多
正为您匹配相似的精品文档
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!

玻璃钢生产厂家承德玻璃钢仿铜雕塑洛阳玻璃钢雕塑定制仿铜玻璃钢运动雕塑商场美陈落地花瓶浙江超市商场美陈供应广东开业商场美陈生产厂家葫芦岛玻璃钢雕塑家居建材商场美陈创意设计优质的玻璃钢雕塑定制抛售玻璃钢动物雕塑赤峰市翁牛特旗玻璃钢动物雕塑合肥景观玻璃钢雕塑定制盱眙玻璃钢龙虾雕塑商场七夕美陈布置大型雕塑玻璃钢鹤壁玻璃钢卡通动物雕塑厂家价格济源天桥玻璃钢花盆定制济源玻璃钢人物雕塑厂家价格贵港玻璃钢群马雕塑实惠的玻璃钢雕塑玻璃钢雕塑合同范本户外玻璃钢雕塑制作银川玻璃钢景区雕塑杭州坚实玻璃钢座椅雕塑商场美陈开标天津景观玻璃钢雕塑设计河南玻璃钢仿铜雕塑泰安人物玻璃钢雕塑定制公园玻璃钢雕塑工程公园景观玻璃钢彩绘雕塑生产香港通过《维护国家安全条例》两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”19岁小伙救下5人后溺亡 多方发声单亲妈妈陷入热恋 14岁儿子报警汪小菲曝离婚始末遭遇山火的松茸之乡雅江山火三名扑火人员牺牲系谣言何赛飞追着代拍打萧美琴窜访捷克 外交部回应卫健委通报少年有偿捐血浆16次猝死手机成瘾是影响睡眠质量重要因素高校汽车撞人致3死16伤 司机系学生315晚会后胖东来又人满为患了小米汽车超级工厂正式揭幕中国拥有亿元资产的家庭达13.3万户周杰伦一审败诉网易男孩8年未见母亲被告知被遗忘许家印被限制高消费饲养员用铁锨驱打大熊猫被辞退男子被猫抓伤后确诊“猫抓病”特朗普无法缴纳4.54亿美元罚金倪萍分享减重40斤方法联合利华开始重组张家界的山上“长”满了韩国人?张立群任西安交通大学校长杨倩无缘巴黎奥运“重生之我在北大当嫡校长”黑马情侣提车了专访95后高颜值猪保姆考生莫言也上北大硕士复试名单了网友洛杉矶偶遇贾玲专家建议不必谈骨泥色变沉迷短剧的人就像掉进了杀猪盘奥巴马现身唐宁街 黑色着装引猜测七年后宇文玥被薅头发捞上岸事业单位女子向同事水杯投不明物质凯特王妃现身!外出购物视频曝光河南驻马店通报西平中学跳楼事件王树国卸任西安交大校长 师生送别恒大被罚41.75亿到底怎么缴男子被流浪猫绊倒 投喂者赔24万房客欠租失踪 房东直发愁西双版纳热带植物园回应蜉蝣大爆发钱人豪晒法院裁定实锤抄袭外国人感慨凌晨的中国很安全胖东来员工每周单休无小长假白宫:哈马斯三号人物被杀测试车高速逃费 小米:已补缴老人退休金被冒领16年 金额超20万

玻璃钢生产厂家 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化