python培训拾遗

20140421

1. 三大利器:

dir----列出所有内部方法

a=1

dir(a) 可以列出所有内部方法,就是带两个下划线的;带一个下划线的是普通方法

help---查看帮助

help(a.bit_length)

type---查看数据类型

type(a)

2. str类型的神奇用法

结果解释说明
"hello"+"world""helloworld"连接
’hello‘*3"hellohellohello"重复
“hello”[0]"h"       第一个位置
"hello"[-1]"o"最后一个位置
"hello"[::-1]"olleh"反转
"hello"[1:4]"ell"取片段,右边界不包含
len("hello")5求长度
"hello"<"jello"1字符串比较
"e" in "hello"1 
"escapes:\n etc,\033 etc, \if etc"  
'single quotes' '''triple quotes''' r''raw strings'' r''表示不会转义,正则表达式中多用
"The %s is %d" %('abc',12)  

3. 容器

  • list ,包括:元素可变---[],元素异构---a=[33,"hiboy",["i', 'am"]]

常用list操作方法

 
操作结果解释说明
a = range(5)5#[0,1,2,3,4]
a.pop()None#[0,1,2,3,4]
a.reverse()None#[4,3,2,1,0]
a.sort()None#[0,1,2,3,4]
a.insert(0,42)None#[42,0,1,2,3,4]在第一个位置插入42
a.append(['another','list'])None#[0,1,2,3,4,['another','list']]
a.extend(['another','list'])None#[0,1,2,3,4,'another','list']
a=[0]*3 #[0,0,0]
  • tuple,元组 包括:元素不可变;元素异构:记住c(0,)逗号必须有,不然就认成别的了
  • dict---key不可变,value可变 a={key:value};元素异构;
 
描述解释说明
a={}空字典
b={'x':3,'y':4} 
c={' uid':105,'login':' beazley',' name':' David Beazley'} 
  
u=c[' uid']获取一个元素值
c[' shell']="/bin/sh"赋值
c['login']=23 
b.get('Perl','unknown')结果是:unknown
b.keys()结果是:[x,y]
b.values()[3,4]
b.items()[('y',4),('x',3)]
d=b.copy():del b['x']

b:{'y':4},d:{'x':3,'y':4}

b[2]=3:b.update(d)

b:{'y':4,2:3},d:{'x':3,'y':4,'2':3}

dict常用于:遍历

items() keys() values()

iteritems() iterkeys() itervalues() --- 元素超过1w时建议使用,效率高;除此之外下面3个和上面的功能没有区别

 

4. 控制

  • if 不多说了
  • for有个神奇的地方:

mylist = "for statement"

for word in mylist:

  print word

else:#最终执行

  print "End list"

  • while不多说

break --终止当前循环

continue--终止本次循环

pass:什么事都不做

  • 由于python不支持switch,故可以使用dict模拟switch:

def f1(a):

  print 1,a

def f2(b):

  print 2,b

def default(d):

  print 'default',4

sw={

  'f1':f1,

  'f2':f2,

  'default':default,

}

sw['f1'](4) #1 4

sw['f2'](5) #2 5

sw['default'](8) #default 4

 

5. 变量,无须声明,初始化等,id(变量名)能够识别是哪个变量的引用 a=1b=1

6. 灵活无比的函数

deffuncname(arg1,arg2=0,*arg3,**arg4): #分别声明普通参数,元组参数,dict字典参数。一个函数中只可以有一个元组和一个字典

  """doc文档描述放这里"""

  statments

  return xx

例如:def gcd(a,b):

  "this is self definition"

  while a!=0:

    a,b=b%a,a

  return b

>>>gcd.__doc__

"this is self definition"

>>>gcd(12,20)

4

又如:

def h(*t):print t

>>>h(1)

(1,)

>>>h(1,2,3,5,6,7)

(1,2,3,5,6,7)

def k(**d):print d

>>>k(m=1,n=2)

{'m':1,'n':2}

  • 函数作用域规则:Local(局部) -> Global(全局) ->Built-in(内置)->NameError异常
  • Python没有函数重载,因为函数是没类型的
  • python函数可以返回多个值么?可以的 tuple
  • 下面函数有什么问题?
  • def func(in,out):print in.out out=2;有问题,关键字不可以用,会覆盖原有意义

 

核心库:

os sys string getopt StringIO struct pickle...

正则库

re module

网络库

socket httplib htmllib ftplib smtplib lxml...

在线参考

标准库:http://docs.python.org/library/index.html

 ppt中的作业,实现如下:遇到的问题是,&&要用and代替;range(m,n)是指从m开始到n-1;raw_input()返回的类型默认是string的,用在这里还需要用isdigit()转换一下,因此改用input();print(),打印后不换行,但有一个空格,还没找到好的去除方法

import sys
n = input("Pls input your number:")
for i in range(1,n+1):
for j in range(1,i+1):
# if (j%2==0) and (i%2==0):
#sys.stdout.write("*")
# print "*",
if (j==(i/2+1)) and (i%2==1):
print "!",
else:
print "*",
print "\n"

 

下面程序的输出是a,c. for each in alist:each相当于有一个指针。each指向第一个元素的时候,打印a;同时remove掉a;这时alist长度变化了,原先第一个元素变成了b;each指针向下走,变成了a;a被打印出来了。因此,这个程序的教训是:不要随意改变列表长度。

alist = ['a','b','c','d']

for each in alist:

  print each  

  alist.remove(each)

模块查找路径依次是:sys.path -- PYTHONPATH -- site-packages

接下来的程序是很常见的用于自测自定义程序是否work的:

#!/usr/bin/python

if __name__=='__main__':

  print 'This program is being run by itself'

else:

  print 'I am bneing imported from another module'

包:包是一个目录树,每个目录下都有一个__init__.py文件

包工具:目前主要是pip;安装包:pip install/uninstall simplejson

类定义中的:

类方法classmethod:整个类只有这么一个方法,

statcitmethod

例子:实现一个堆栈

class Stack(object):

"A well-known data structure..."

def __init__(self): #构造函数

  self.items = []

def push(self,x):

  self.items.append(x) 

def pop(self):

  x=self.items[-1]

  del self.items[-1]

  return x

def empty(self):

  return len(self.items)==0

x=Stack()

x.empty()  # True

x.push(1)  # [1]

x.empty()  # False

x.push("hello")  # [1,"hello"]

x.pop()  #hello

x.items  #[1]

类 - 继承

class SchoolMember(object):

'''Rmpresents any school member.'''

def __init__(self,name,age):

  self.name = name

  self.age - age

  print '(Initialized SchoolMember:%s)' % self.name

def tell(self):

'''Tell my details.'''

  print 'Name:"%s" Age:"%s"' %(self.name,self.age),

class Teacher(SchoolMember):

'''Represents a teacher.'''

def __init__(self,name,age,salary):

  SchoolMember.__init__(self,name,age)

  self.salary = salary

  print '(Initialized Teacher:%s)' % self.name

def tell(self):

  SchoolMember.tell(self)

  print 'Salary:"%d"' % self.salary

class Student(SchoolMember):

def __init__(self,name,age,score):

SchoolMember.__init__(self,name,age)

self.score = score

 

t=Teacher('Mrs.Shrividya',40,30000) #实例化

s = Student('Swaroop',22,75)

t.tell()

s.tell()

转载于:https://www.cnblogs.com/ianthe/p/3679578.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值