Python 学习小结

openkk 13年前

1 使用idel新建立程序后,保存运行,CTRL+F5即可运行

2  if (time==12):
      print 'hello'
else:
     pring 'dsdsd'

//注意冒号!

3 包、模块的命名规则:全部以小写字母形式命名

4 类名首字母大写,其他字母小写;私有属性和私有方法用两个下划线做前缀,SELF=JAVA中的this

5 函数命名规则:函数名必须下划线或者字母开头,可以包含任意的数字,字母和下划线组合,函数名
区分大小写,函数名不能保留字

6 注释用 #号,中文注释  #* coding:UTF-8 *

7 PYTHON不强制使用分号

8 PYTHON类型
   1) 整型
      分别为布尔型(0:FALSE,1:TRUE),长整型和标准整数类型;长整型相当于JAVA.BIGINTEGER,在后
面加L表示
   

   2)双精度类型,E记数,相当于c的double
   3)复数,比如0+2j,其中num.real,num.imag分别返回其实部和虚部,num.conjugate(),返回其共扼复数对象
 
  
9 PYTHON不支持i++,i--的运算

10 全局变量,使用global 关键字

11 字符串知识
   1)‘hello'  --//输出'hello'  原样输出hello
   2)  "hello"   //输出"hello"
   3) "what 's your name"    输出"what's your name
   4)三引号:其中的字符串可以任意使用单引号和双引号
   >>> '''what's your name,'this is a pig' '''
  输出:"what's your name,'this is a pig' "

   5)也可以转义,比如
      >>>'what \'s your name'
    6) 字符串连接用+号
     7)print str('hello')  //输出hello,将其转为字符串的形式

   8)字符串的输入函数   input(),把输入数据改为默认的python表达
式,而raw_input()是将读入的数据转换为字符串
     比如raw_input('我的年龄')

12 整除
    3/6=0,这时因为两个整数除的时候,python 2.5会对结果进行截取,只保留
整数部分。
   3.0/6.0=0.5  ,如果参与除法个数中有一个是浮点数字,则是真正除(5。0/6)
  from future import division
真除法:5/6=0.83333     
而//叫地板除  用于两个数的整除,比如5//6=0
  乘方运算
   3
3=27


13 falas,none,0,空字符串,空元素,空列表及空字典都是假(0),而其他值都是真值‘

14 if语句
   if  xxxx:
print ''
elif xxxx:
print 'xxxx'
elif xxx:
print 'xxxx'
  注意是elif

15 while语句
      while i<=5:
      .......
      else:
        ...........

16 for循环
   for target in object:
     ....
     if  xxxx:
     break
if   xxxxx:
   continue
else:
    .......

17 迭代器
    mab=['a','b','c','d']
    my=iter(mab)
 
    print my.next()
     print my.next()
   
  
  并行迭代:
   names=[a','b','c','d']
   ages=[2,4,5,7]
   for name,age in zip(names,ages) :
       print name,'的年龄是',age

   zifu=raw_input('输入您要查询鲜花的名称:')
shujus=['长春花','珍珠花','向日葵','风铃草','金盏菊','含羞草','夹竹桃','大丽花','金雀花','野蔷薇','桔梗花']
for index,shuju in enumerate(shujus):
if zifu in shuju:
print shuju

   //其中enumerate为迭代器

18 while True:
    word=raw_input('input name')
    if not word:
    break
     ..........
19 PASS语句
   什么也不做

20 DEL语句
    删除名称本身
    name='abc'
     del name
   print name
  
  动态执行python代码
     exec "print 'hello'"
   

21 PYTHON程序结构
    由包,模块和函数组成
22
  # 函数的定义
def login (username = "maxianglin" , password = "maxianglin"):
    if(username == 'admin') and (password == 'admin'):
        print "登录成功!"
    else:
        print "登录失败"
login('admin','admin')
login('admin')
login(password='admin')
login()

23 注意PYTHON 2下,WINDOWS下的话,里面有中文的话,将其保存为GBK编码再运行,PYTHON3则没这个问题。

24 函数中的可变长度参数值
     比如def login ( userpwds):
          username=userpwds[0];
          ...................
      调用login('a','b')
25 方法需要返回值的话,则只需要return 即可
26  方法需要返回多个值,可以使用元组的方法
     比如def  abc(x,y,z)
           x=x+5
           y=y+4
           z=z+6
         opera=[x,y,z]
         numbers=tuple(opera)
         return numbers

27 模块的创建

       abc.py
       def test():
       .......

调用方:
      import  abc
       ab.test();

//或者from abc import test
      from abc import
  //导入所有模块     

  python的import可以放在任何位置


28 # -- coding: UTF-8 --
import sys

print updatePwd.updatePassword().decode('UTF-8').encode(type)
        用这里调用结果用decode转换为UTF-8了


29 模块中的属性
    1) name属性 :用来判断当前模块是不是程序的入口,如果是入口,则返回main

    2) DOC:每个对象都会有doc,用来描述注释作用,比如
      class myclass:
           'adsdfsdfsdf'
           ...............
       print myclass.doc  //输出adsdfsdfsdf

30) 内设的模块函数
    1、apply()函数
      def login (username , password):
    msg = ''
    if(username == 'admin') and (password == 'admin'):
        msg = '登录成功'
    else:
        msg = '登录失败'
    return msg
print apply(login,('admin','admin'))
    把函数的参数存放在一个元组或序列中

   2 filter()函数
     用函数来过滤序列,把序列的每一个项传递到过滤函数中去,如果函数返回TRUE则过滤,并一次性返回
其结果,如果过滤函数返回的结果为FALSE,则从列表中删除该项目。
        def validate (usernames):
    if (len(usernames) > 4) and (len(usernames) < 12):
        return usernames
print filter(validate , ('admin','maxianglin','mxl','adm','wanglili'))

     将('admin','maxianglin','mxl','adm','wanglili')传进去进行过滤

   3 reduce函数
       def operat (x , y):
    return xy

print reduce(operat , (1,2,3,4,5,6))
print reduce(operat , (7,8,9) , 5)
    其中,对(1,2,3,4,5,6)进行每一个的连乘;

    4 map函数
      对多个序列中的每个元素执行相同的操作,并返回一个与输入序列长度相同的列表。
    def add1(a):  
    return a + 1 
def add2(a, b):  
    return a + b  
def add3(a, b, c):  
    return a + b + c
   
a1 = [1,2,3,4,5]  
a2 = [1,2,3,4,5]  
a3 = [1,2,3,4,5]  
 
b = map(add1, a1)  
print b  
b = map(add2, a1, a2)  
print b  
b = map(add3, a1, a2, a3)
print b

  分别输出:[2, 3, 4, 5, 6]
[2, 4, 6, 8, 10]
[3, 6, 9, 12, 15]


31 LIST
  1)   userList = ['0001' , '0002' , '0003' , '0004' , '0005']
print '目前有学生'+str(len(userList))+'个'
print '刚来一个学生'
userList.append('0006')
print '现有学生'+str(len(userList))+'个,他们是:'
for item in userList:
    print item
   2) insert方法
       userList = ['0001' , '0002' , '0006' , '0004' , '0005']
print '初始化的userList列表为:'+str(userList)
userList[2] = '0003'
print '更新后的userList列表为:'+str(userList)
     //注意序列从0开始算

  3) 删除元素remove
         userList = ['0001' , '0002' , '0003' , '0004' , '0005']
print '初始化的userList列表为:'+str(userList)
#userList.remove('0003')
   4)del
     del userlist[1]
   5) 分片赋值
       userList = list('Python')
userList[1:] = list('rite')
print userList
    这里用冒号分片,从第3个元素开始到结束,改为rity,输出pyrite

   
   6)使用负索引访问列表元素
         userList = ['0001' , '0002' , '0003' , '0004' , '0005' , '0006']
print userList[-2]
   最尾部元素为-1,-2即输出005
  7) 列表分片
      userList = ['0001' , '0002' , '0003' , '0004' , '0005' , '0006']
subUser1= userList[2:5] //输出索引2,3,4号位的元素,不包括索引为5的元素

subUser2= userList[-3:-1]
subUser3= userList[0:-2] //输入不0开始,不包括-2元素位(即0005)的所有元素
print subUser1
print subUser2
print subUser3

   ['0003', '0004', '0005']
['0004', '0005']
['0001', '0002', '0003', '0004']
   

  
8) 二元表
    有点象数组:
      userList1=['0001' , '0002' , '0003' , '0004']
userList2=['0005' , '0006' , '0007']
userList=[userList1 , userList2]
   则userList[0][1]=0002
  列表可以连接:
   userList1=['0001' , '0002' , '0003' , '0004']
userList2=['0005' , '0006' , '0007']
userList1.extend(userList2)
print userList1
   将userLIst2加到userList1后去
     userList6= ['0015' , '0016']
2  //将其中的元素添加一杯  ['0015','0016','0015','0016']


9 ) 列表的查找,排序和反转
   查找:userList = ['0001' , '0002' , '0003' , '0004' , '0005' , '0006']
print '元素0002对应的索引值为:',userList.index('0002')
   排序:userList = ['0001' , '0004' , '0006' , '0002' , '0005' , '0003']
userList.sort(reverse=True)
print userList
   //默认是升序,如果设置参数reverse=true,则为降序
   反转:userList = ['0001' , '0004' , '0006' , '0002' , '0005' , '0003']
userList.reverse()

32 POP操作:userlist.pop() //弹出
   append:入栈操作 
    
33 不可变序列:元组
   1) 创建元组,创建时可以不指定元素的个数,相当于不定长的数组,但一旦创建就不能修改元组的长度。
  如果只有一个数的元组,则必须指定为比如(42,),注意后面加上一个逗号
    元组:  user=('1','2','3','4','5')  ,元组的长度不可变,同样索引从0开始

   2) 添加元组
     userTuple = ('0001'  , '0002' , '0003' , '0004' , '0005' , '0006')
new_userTupele=(userTuple , '0007' , '0008')
  3 )元组中的元素不能修改
  4) 同样支持分片
      userTuple = ('0001'  , '0002' , '0003' , '0004' , '0005' , '0006')
print '元组中的第3个元素为:',userTuple[2]
print '元组中倒数第3个元素为:',userTuple[-3]
print '元组中第3个元素到倒数第2个元素组成的元组为:',userTuple[2:-1]

  5) 元组可以进行解包操作
       userTuple = ('0001' , '0002' , '0003')
stu1 , stu2 , stu3 = userTuple
print stu1
print stu2
print stu3
  6)元组的遍历
      for range的用法
    userTuple = ('0001' , '0002' , '0003' , '0004' , '0005' , '0006')
for item in range(len(userTuple)):
    print userTuple[item]
  还可以用MAP
    userTuple1 = ('0001' , '0002' , '0003')
userTuple2 = ('0004' , '0005' , '0006')
userTuple=(userTuple1 , userTuple2)
for item in map(None , userTuple):
    for i in item:
        print i
      MAP中的NONE时,则MAP返回其后面的元组

34 字典
     userDic = [(2,'maxianglin'),(1,'wanglili'),(3,'malinlin')]
dic_userDic = dict(userDic)
print dic_userDic
  输出为:{1:'wanglili',2:'maxlinlin',3:'malinlin'}
   或者usera={'0000':'sssss','ssss':'tom'}
  操作:
   1) 字典添加元素
     字典是无序的,没append方法,向其调用增加一个元素,用setdeffault()方法
   userDic={'0001':'maxianglin','0002':'wanglili','0003':'malinlin'}
userDic.setdefault('0004','zhuhongtao')
print userDic
userDic.setdefault('0001','zhangfang') //重复元素,添加失败,依然是原来的
print userDic
    也可以直接改值  userDic['0004']='ddddd'
   删除值:
     del(userdic['0002']);
  也可以  userdic.pop
      
    2) 字典的遍历
       for in遍历
   userDic={'0001':'maxianglin','0002':'wanglili','0003':'malinlin'}
#for key in userDic:
    #print 'userDic[%s]='% key,userDic[key]
print userDic.items()
      还有用items方法遍历字典,比如
   userDic={'0001':'maxianglin','0002':'wanglili','0003':'malinlin'}
for (key,value) in userDic.iteritems():
    print 'userDic[%s]='% key,value
     还有iterkeys()和itervalues,
      for key in userDic.iterkeys():
    print key
for value in userDic.itervalues():
    print value
    
for (key ,value) in zip(userDic.iterkeys(),userDic.itervalues()):
    print 'userDic[%s]='% key,value

   3) 字典的基础方法
     clear():清除字典里的所有项  userDic.clear()
     copy()方法:userDic.copy()
     fromkeys()方法: 
       source_userDic= {'0001':'maxianglin','0002':'wanglili','0003':'malinlin'}
print {}.fromkeys(['0001','0002'])
print source_userDic.fromkeys(['0001','0002'])
print source_userDic.fromkeys(['0001','0002'],'maxianglin')
  其中fromkeys中第一个参数是新的字典的列表,第2个参数是值
     {'0001': None, '0002': None}
{'0001': None, '0002': None}
{'0001': 'maxianglin', '0002': 'maxianglin'}

 4) 字典的get方法
     userDic= {'0001':'maxianglin','0002':'wanglili','0003':'malinlin'}
   print userDic.get('0002')
    //当get访问不存在的值的时候,返回的是NONE,不会有异常
 5) has_key()方法
    找字典中是否有该键,如果有返回true.
       userDic.has_key('abc')
  6)popitem()方法
    弹出栈,userDic.popitem()
7) update方法,用一个字典更新另外一个字典
    userDic= {'0001':'maxianglin','0002':'wanglili','0003':'malinlin'}
newDic={'0002':'zhangfang'}
userDic.update(newDic)
print userDic
   则更新0002的值
 

35  序列
   numbers=[0,1,2,3,4,5,6,7,8,9]
      numbers[3:6] ,表示从第3个元素开始,但不包括第6个元素的值,输出3,4,5
      numbers[7:]  则取到最后,从第7个开始,即7,8,9
   更大的步长
   又如numbers[0:10:1] ,指定了步长为1,默认为1,输出[0,1,2,3,4,5,6,7,8,9]

   如果设置步长为2,则跳过元素
   [0,2,4,6,8]
   还可以number[::3],只有步长,输出[0,3,6,9]

转自:http://jackyrong.iteye.com/blog/1404268