收藏 分销(赏)

python经典实例.doc

上传人:精**** 文档编号:3130219 上传时间:2024-06-19 格式:DOC 页数:11 大小:50KB
下载 相关 举报
python经典实例.doc_第1页
第1页 / 共11页
python经典实例.doc_第2页
第2页 / 共11页
python经典实例.doc_第3页
第3页 / 共11页
python经典实例.doc_第4页
第4页 / 共11页
python经典实例.doc_第5页
第5页 / 共11页
点击查看更多>>
资源描述

1、1 输出你好#打开新窗口,输入:#!/usr/bin/python#-*-coding:utf8-*-s1=input(Inputyourname:)print(你好,%s%s1)知识点:*input(某字符串)函数:显示某字符串,并等待用户输入.*print()函数:如何打印.*如何应用中文 *如何用多行注释2 输出字符串和数字但有趣的是,在javascript里我们会理想当然的将字符串和数字连接,因为是动态语言嘛.但在Python里有点诡异,如下:#!/usr/bin/pythona=2b=testc=a+b运行这行程序会出错,提示你字符串和数字不能连接,于是只好用内置函数进行转换#!/u

2、sr/bin/python#运行这行程序会出错,提示你字符串和数字不能连接,于是只好用内置函数进行转换a=2b=testc=str(a)+bd=1111e=a+int(d)#Howtoprintmultiplyvaluesprint(cis%s,eis%i%(c,e)知识点:*用int和str函数将字符串和数字进行转换*打印以#开头,而不是习惯的/*打印多个参数的方式3 列表#!/usr/bin/python#-*-coding:utf8-*-#列表类似Javascript的数组,方便易用#定义元组word=a,b,c,d,e,f,g#如何通过索引访问元组里的元素a=word2print(ai

3、s:+a)b=word1:3print(bis:)print(b)#index1and2elementsofword.c=word:2print(cis:)print(c)#index0and1elementsofword.d=word0:print(dis:)print(d)#Allelementsofword.#元组可以合并e=word:2+word2:print(eis:)print(e)#Allelementsofword.f=word-1print(fis:)print(f)#Thelastelementsofword.g=word-4:-2print(gis:)print(g)#i

4、ndex3and4elementsofword.h=word-2:print(his:)print(h)#Thelasttwoelements.i=word:-2print(iis:)print(i)#Everythingexceptthelasttwocharactersl=len(word)print(Lengthofwordis:+str(l)print(Addsnewelement)word.append(h)print(word)#删除元素delword0print(word)delword1:3print(word)知识点:*列表长度是动态的,可任意添加删除元素.*用索引可以很方便

5、访问元素,甚至返回一个子列表*更多方法请参考Python的文档4 字典#!/usr/bin/pythonx=a:aaa,b:bbb,c:12print(xa)print(xb)print(xc)forkeyinx:print(Keyis%sandvalueis%s%(key,xkey)知识点:*将他当Java的Map来用即可.5 字符串比起C/C+,Python处理字符串的方式实在太让人感动了.把字符串当列表来用吧.#!/usr/bin/pythonword=abcdefga=word2print(ais:+a)b=word1:3print(bis:+b)#index1and2elements

6、ofword.c=word:2print(cis:+c)#index0and1elementsofword.d=word0:print(dis:+d)#Allelementsofword.e=word:2+word2:print(eis:+e)#Allelementsofword.f=word-1print(fis:+f)#Thelastelementsofword.g=word-4:-2print(gis:+g)#index3and4elementsofword.h=word-2:print(his:+h)#Thelasttwoelements.i=word:-2print(iis:+i)#

7、Everythingexceptthelasttwocharactersl=len(word)print(Lengthofwordis:+str(l)中文和英文的字符串长度是否一样?#!/usr/bin/python#-*-coding:utf8-*-s=input(输入你的中文名,按回车继续);print(你的名字是:+s)l=len(s)print(你中文名字的长度是:+str(l)知识点: 类似Java,在python3里所有字符串都是unicode,所以长度一致.6 条件和循环语句#!/usr/bin/python#条件和循环语句x=int(input(Pleaseenteranint

8、eger:)ifx0:x=0print(Negativechangedtozero)elifx=0:print(Zero)else:print(More)#LoopsLista=cat,window,defenestrateforxina:print(x,len(x)#知识点:#*条件和循环语句#*如何得到控制台输入7 函数#!/usr/bin/python#-*-coding:utf8-*-defsum(a,b):returna+bfunc=sumr=func(5,6)print(r)#提供默认值defadd(a,b=2):returna+br=add(1)print(r)r=add(1,5

9、)print(r)一个好用的函数#!/usr/bin/python#-*-coding:utf8-*-#Therange()functiona=range(1,10)foriina:print(i)a=range(-2,-11,-3)#The3rdparameterstandsforstepforiina:print(i)知识点: Python 不用来控制程序结构,他强迫你用缩进来写程序,使代码清晰. 定义函数方便简单 方便好用的range函数8 异常处理#!/usr/bin/pythons=input(Inputyourage:)ifs=:raiseException(Inputmustno

10、beempty.)try:i=int(s)exceptExceptionaserr:print(err)finally:#Cleanupactionprint(Goodbye!)9 文件处理对比Java,python的文本处理再次让人感动#!/usr/bin/pythonspath=D:/download/baa.txtf=open(spath,w)#Opensfileforwriting.Createsthisfiledoesntexist.f.write(Firstline1.n)f.writelines(Firstline2.)f.close()f=open(spath,r)#Opens

11、fileforreadingforlineinf:print(每一行的数据是:%s%line)f.close()知识点: open的参数:r表示读,w写数据,在写之前先清空文件内容,a打开并附加内容. 打开文件之后记得关闭10 类和继承classBase:def_init_(self):self.data=defadd(self,x):self.data.append(x)defaddtwice(self,x):self.add(x)self.add(x)#ChildextendsBaseclassChild(Base):defplus(self,a,b):returna+boChild=Ch

12、ild()oChild.add(str1)print(oChild.data)print(oChild.plus(2,3)知识点:*self:类似Java的this参数11 包机制每一个.py文件称为一个module,module之间可以互相导入.请参看以下例子:# a.pydefadd_func(a,b):returna+b#b.pyfromaimportadd_func#Alsocanbe:importaprint(Importadd_funcfrommodulea)print(Resultof1plus2is:)print(add_func(1,2)#Ifusingimporta,the

13、nhereshouldbea.add_funcmodule可以定义在包里面.Python定义包的方式稍微有点古怪,假设我们有一个parent文件夹,该文件夹有一个child子文件夹.child中有一个module a.py . 如何让Python知道这个文件层次结构?很简单,每个目录都放一个名为_init_.py 的文件.该文件内容可以为空.这个层次结构如下所示:parent-_init_.py-child-_init_.py-a.pyb.py那么Python如何找到我们定义的module?在标准包sys中,path属性记录了Python的包路径.你可以将之打印出来:importsysprin

14、t(sys.path)通常我们可以将module的包路径放到环境变量PYTHONPATH中,该环境变量会自动添加到sys.path属性.另一种方便的方法是编程中直接指定我们的module路径到sys.path 中:importsysimportossys.path.append(os.getcwd()+parentchild)print(sys.path)fromaimportadd_funcprint(sys.path)print(Importadd_funcfrommodulea)print(Resultof1plus2is:)print(add_func(1,2)知识点: 如何定义模块和

15、包 如何将模块路径添加到系统路径,以便python找到它们 如何得到当前路径12 内建帮助手册对比C+,Java的突出进步是内建Javadoc机制,程序员可以通过阅读Javadoc了解函数用法.Python也内建了一些方便函数以便程序员参考. dir函数: 查看某个类/对象的方法. 如果有某个方法想不起来,请敲dir. 在idle里,试试 dir(list) help函数: 详细的类/对象介绍. 在idle里, 试试 help(list)1 遍历文件夹和文件 import osimport os.path# os,os.path里包含大多数文件访问的函数,所以要先引入它们. # 请按照你的实际

16、情况修改这个路径 rootdir = d:/download for parent,dirnames,filenames in os.walk(rootdir): # case1: for dirname in dirnames: print ( parentis: + parent) print ( dirnameis: + dirname) # case2 for filename in filenames: print ( parentis: + parent) print ( filenamewithfullpath: + os.path.join(parent,filename) 知

17、识点:*os.walk返回一个三元组.其中dirnames是所有文件夹名字(不包含路径),filenames是所有文件的名字(不包含路径).parent表示父目录.*case1演示了如何遍历所有目录.*case2演示了如何遍历所有文件.*os.path.join(dirname,filename):将形如/a/b/c和d.java变成/a/b/c/d.java. 2 分割路径和文件名 import os.path# 常用函数有三种:分隔路径,找出文件名.找出盘符(windows系统),找出文件的扩展名. # 根据你机器的实际情况修改下面参数. spath = D:/download/repos

18、itory.7z # case1: p,f = os.path.split(spath);print ( diris: + p)print ( fileis: + f)# case2: drv,left = os.path.splitdrive(spath);print ( driveris: + drv)print ( leftis: + left)# case3: f,ext = os.path.splitext(spath);print ( fis: + f)print ( extis: + ext) 知识点:这三个函数都返回二元组.*case1分隔目录和文件名*case2分隔盘符和文件

19、名*case3分隔文件和扩展名 总结:5个函数 os.walk(spath) os.path.split(spath) os.path.splitdrive(spath) os.path.splitext(spath) os.path.join(path1,path2) 3 复制文件 import shutilimport osimport os.pathsrc = d:downloadtestmyfile1.txt dst = d:downloadtestmyfile2.txt dst2 = d:/download/test/测试文件夹.txt dir1 = os.path.dirname(

20、src)print ( dir1%s % dir1)if (os.path.exists(src) = False):os.makedirs(dir1)f1 = open(src, w )f1.write( linean )f1.write( linebn )f1.close()shutil.copyfile(src,dst)shutil.copyfile(src,dst2)f2 = open(dst, r )for line in f2: print (line)f2.close()# 测试复制文件夹树 try :srcDir = d:/download/test dstDir = d:/d

21、ownload/test2 # 如果dstDir已经存在,那么shutil.copytree方法会报错! # 这也意味着你不能直接用d:作为目标路径. shutil.copytree(srcDir,dstDir)except Exceptionaserr: print (err) 知识点:*shutil.copyfile:如何复制文件*os.path.exists:如何判断文件夹是否存在*shutil.copytree:如何复制目录树 总结:4个函数 os.path.dirname(path) os.path.exists(path) shutil.copyfile(src, dst) shutil.copytree(srcDir, dstDir)

展开阅读全文
相似文档                                   自信AI助手自信AI助手
猜你喜欢                                   自信AI导航自信AI导航
搜索标签

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2024 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服