Python已经是3.1版本了,与时俱进更新教程.
本文适合有Java编程经验的程序员快速熟悉Python
本文程序在windows xp+python3.1a1 测试通过.
本文提到的idle指python shell,即安装python后你在菜单看到的IDLE(python gui)
在idle里ctrl+n可以打开一个新窗口,输入源码后ctrl+s可以保存,f5运行程序.
凡打开新窗口即指ctrl+n的操作.
1 你好
#打开新窗口,输入:#! /usr/bin/python#-*- coding: utf8 -*-s1=input("Input your name:")print("你好,%s"%s1)'''知识点:
* input("某字符串")函数:显示"某字符串",并等待用户输入.
* print()函数:如何打印.
* 如何应用中文* 如何用多行注释
'''
2 字符串和数字
但有趣的是,在javascript里我们会理想当然的将字符串和数字连接,因为是动态语言嘛.但在Python里有点诡异,如下:
#! /usr/bin/pythona=2b="test"c=a+b
运行这行程序会出错,提示你字符串和数字不能连接,于是只好用内置函数进行转换
#! /usr/bin/python#运行这行程序会出错,提示你字符串和数字不能连接,于是只好用内置函数进行转换a=2b="test"c=str(a)+b
d="1111"e=a+int(d)#How to print multiply valuesprint("c is %s,e is %i"%(c,e))'''知识点:
* 用int和str函数将字符串和数字进行转换
* 打印以#开头,而不是习惯的//
* 打印多个参数的方式'''
3 列表
#! /usr/bin/python#-*- coding: utf8 -*-#列表类似Javascript的数组,方便易用#定义元组word=['a','b','c','d','e','f','g']#如何通过索引访问元组里的元素a=word[2]print("a is:"+a)
b=word[1:3]print("b is:")print(b)#index 1 and 2 elements of word.c=word[:2]print("c is:")print(c)#index 0 and 1 elements of word.d=word[0:]print("d is:")print(d)#All elements of word.#元组可以合并e=word[:2]+word[2:]print("e is:")print(e)#All elements of word.f=word[-1]print("f is:")print(f)#The last elements of word.g=word[-4:-2]print("g is:")print(g)#index 3 and 4 elements of word.h=word[-2:]print("h is:")print(h)#The last two elements.i=word[:-2]print("i is:")print(i)#Everything except the last two charactersl=len(word)print("Length of word is:"+str(l))print("Adds new element")
word.append('h')print(word)#删除元素delword[0]print(word)delword[1:3]print(word)'''知识点:
* 列表长度是动态的,可任意添加删除元素.
* 用索引可以很方便访问元素,甚至返回一个子列表
* 更多方法请参考Python的文档'''
4 字典
#! /usr/bin/pythonx={'a':'aaa','b':'bbb','c':12}print(x['a'])print(x['b'])print(x['c'])forkeyinx:print("Key is %s and value is %s"%(key,x[key]))'''知识点:
* 将他当Java的Map来用即可.'''
5 字符串
比起C/C++,Python处理字符串的方式实在太让人感动了.把字符串当列表来用吧.
#! /usr/bin/python
word="abcdefg"a=word[2]print("a is:"+a)
b=word[1:3]print("b is:"+b)#index 1 and 2 elements of word.c=word[:2]print("c is:"+c)#index 0 and 1 elements of word.d=word[0:]print("d is:"+d)#All elements of word.e=word[:2]+word[2:]print("e is:"+e)#All elements of word.f=word[-1]print("f is:"+f)#The last elements of word.g=word[-4:-2]print("g is:"+g)#index 3 and 4 elements of word.h=word[-2:]print("h is:"+h)#The last two elements.i=word[:-2]print("i is:"+i)#Everything except the last two charactersl=len(word)print("Length of word is:"+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("Please enter an integer:"))ifx<0:
x=0print("Negative changed to zero")elifx==0:print("Zero")else:print("More")#Loops Lista=['cat','window','defenestrate']forxina:print(x, len(x))#知识点:#* 条件和循环语句#* 如何得到控制台输入
7 函数
#! /usr/bin/python#-*- coding: utf8 -*-defsum(a,b):returna+b
func=sum
r=func(5,6)print(r)#提供默认值defadd(a,b=2):returna+b
r=add(1)print(r)
r=add(1,5)print(r)
一个好用的函数
#! /usr/bin/python#-*- coding: utf8 -*-#The range() functiona=range (1,10)foriina:print(i)
a=range(-2,-11,-3)#The 3rd parameter stands for stepforiina:print(i)
知识点:
Python 不用{}来控制程序结构,他强迫你用缩进来写程序,使代码清晰.
定义函数方便简单
方便好用的range函数
8 异常处理
#! /usr/bin/pythons=input("Input your age:")ifs=="":raiseException("Input must no be empty.")try:
i=int(s)exceptValueError:print("Could not convert data to an integer.")except:print("Unknown exception!")else:#It is useful for code that must be executed if the try clause does not raise an exceptionprint("You are %d"%i,"years old")finally:#Clean up actionprint("Goodbye!")
9 文件处理
对比Java,python的文本处理再次让人感动
#! /usr/bin/pythonspath="D:/download/baa.txt"f=open(spath,"w")#Opens file for writing.Creates this file doesn't exist.f.write("First line 1.\n")
f.writelines("First line 2.")
f.close()
f=open(spath,"r")#Opens file for readingforlineinf: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)#Child extends BaseclassChild(Base):defplus(self,a,b):returna+b
oChild=Child()
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#Also can be : import aprint("Import add_func from module a")print("Result of 1 plus 2 is:")print(add_func(1,2))#If using "import a" , then here should be "a.add_func"
module可以定义在包里面.Python定义包的方式稍微有点古怪,假设我们有一个parent文件夹,该文件夹有一个child子文件夹.child中有一个module a.py . 如何让Python知道这个文件层次结构?很简单,每个目录都放一个名为_init_.py 的文件.该文件内容可以为空.这个层次结构如下所示:
parent--__init_.py--child--__init_.py--a.py
b.py
那么Python如何找到我们定义的module?在标准包sys中,path属性记录了Python的包路径.你可以将之打印出来:
import sys
print(sys.path)
通常我们可以将module的包路径放到环境变量PYTHONPATH中,该环境变量会自动添加到sys.path属性.另一种方便的方法是编程中直接指定我们的module路径到sys.path 中:
importsysimportos
sys.path.append(os.getcwd()+'\\parent\\child')print(sys.path)fromaimportadd_funcprint(sys.path)print("Import add_func from module a")print("Result of 1 plus 2 is:")print(add_func(1,2))
知识点:
如何定义模块和包
如何将模块路径添加到系统路径,以便python找到它们
如何得到当前路径
来自:http://www.cnitblog.com/yunshichen/archive/2009/04/01/55924.html
12 内建帮助手册
对比C++,Java的突出进步是内建Javadoc机制,程序员可以通过阅读Javadoc了解函数用法.Python也内建了一些方便函数以便程序员参考.
dir函数: 查看某个类/对象的方法. 如果有某个方法想不起来,请敲dir. 在idle里,试试 dir(list)
help函数: 详细的类/对象介绍. 在idle里, 试试 help(list)
1 遍历文件夹和文件
import osimport os.path# os,os.path里包含大多数文件访问的函数,所以要先引入它们. # 请按照你的实际情况修改这个路径 rootdir = " d:/download " for parent, dirnames, filenames in os.walk(rootdir): # case 1: for dirname in dirnames: print ( " parent is: " + parent) print ( " dirname is: " + dirname) # case 2 for filename in filenames: print ( " parent is: " + parent) print ( " filename with full path : " + os.path.join(parent, filename))''' 知识点:
* 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/repository.7z " # case 1: p,f = os.path.split(spath);print ( " dir is: " + p)print ( " file is: " + f)# case 2: drv,left = os.path.splitdrive(spath);print ( " driver is: " + drv)print ( " left is: " + left)# case 3: f,ext = os.path.splitext(spath);print ( " f is: " + f)print ( " ext is: " + ext)''' 知识点: 这三个函数都返回二元组.
* case1 分隔目录和文件名
* case2 分隔盘符和文件名
* case3 分隔文件和扩展名'''
总结:5个函数
os.walk(spath)
os.path.split(spath)
os.path.splitdrive(spath)
os.path.splitext(spath)
os.path.join(path1,path2)
3 实战:文件备份小程序
import osimport shutilimport datetime''' 作用:将目录备份到其他路径。
实际效果:
假设给定目录"/media/data/programmer/project/python" ,
备份路径"/home/diegoyun/backup/“ ,
则会将python目录备份到备份路径下,形如:
/home/diegoyun/backup/yyyymmddHHMMSS/python/xxx/yyy/zzz
..
用法:更改这两个参数.
backdir:备份目的地.
copydirs:想要备份的文件夹.''' def mainLogic(): # add dirs you want to copy backdir = " d:\\test " print (backdir)
copydirs = []
copydirs.append( " d:\\temp " ); # copydirs.append("d:\\test"); print ( " Copying files =================== " )
start = datetime.datetime.now() # gen a data folder for backup backdir = os.path.join(backdir,start.strftime( " %Y-%m-%d " )) # print("backdir is:"+backdir) kc = 0 for d in copydirs:
kc = kc + copyFiles(d,backdir)
end = datetime.datetime.now() print ( " Finished! =================== " ) print ( " Total files : " + str(kc) ) print ( " Elapsed time : " + str((end - start).seconds) + " seconds " )def copyFiles(copydir,backdir):
prefix = getPathPrefix(copydir) # print("prefix is:"+prefix ) i = 0 for dirpath,dirnames,filenames in os.walk(copydir): for name in filenames:
oldpath = os.path.join(dirpath,name)
newpath = omitPrefix(dirpath,prefix) print ( " backdir is: " + backdir )
newpath = os.path.join(backdir,newpath) print ( " newpath is: " + newpath) if os.path.exists(newpath) != True:
os.makedirs(newpath)
newpath = os.path.join(newpath,name) print ( " From: " + oldpath + " to: " + newpath)
shutil.copyfile(oldpath,newpath)
i = i + 1 return idef getPathPrefix(fullpath): # Giving /media/data/programmer/project/ , get the prefix # /media/data/programmer/ l = fullpath.split(os.path.sep) # print(str(l[-1]=="") if l[ - 1 ] == "" :
tmp = l[ - 2 ] else :
tmp = l[ - 1 ] return fullpath[0:len(fullpath) - len(tmp) - 1 ]def omitPrefix(fullpath,prefix): # Giving /media/data/programmer/project/python/tutotial/file/test.py , # and prefix is Giving /media/data/programmer/project/, # return path as python/tutotial/file/test.py return fullpath[len(prefix) + 1 :]
mainLogic()
来自:http://www.cnitblog.com/yunshichen/archive/2009/04/01/55931.html