《python核心编程》学习笔记

if __name__ == '__main__':


一、二、三

获得键盘输入
  1、raw_input('')
  2、sys.stdin.readline()

strip()取出2边的空格。

3<5>4 等同于 (3<5)and(4<5),这个可是当初C语言入门的时候经常叮嘱的经典错误呀!想不到在这里被实现了,再也不是错误了,呵呵。

print 和c里面的printf基本一致。
  print "str %s , int %d"%('str1',456)

对字符串构造也可以使用,类似sprintf,或者CString.format
  str2 = "int %d"%(123)
  str2 = 'int 123'

列表(list) 中括号[] 可以改元素
  表列(tuple)小括号() 不可以改元素,相当于常量
  字典(disk)大括号{} 第二项可改

a=[1,2,3,4]
  >>>a[2:]
  [3,4]
  >>>a[:3]
  [1,2,3]

dist1={}
  dist1.keys()

>>> range(9)
  [0, 1, 2, 3, 4, 5, 6, 7, 8]
  for i in range(9):
  等同于
  while i<9:
   i++

>>>print 1,2,3
  1 2 3
  逗号可以连接字符串,但是添加一个空格

# 注释
  \n 换行
  \ 续行
  ; 同行2语句
  : 分割标题行和后续语句
  ''' ''' 文档,可以随意换行

del 删除引用,如果是把内置函数给重新设置了引用,del后回归默认。不能删除内置函数。
  比如 dir='123'那么dir就失去了原来的作用,当del dir后,回归原始作用。

id(x)显示某个对象的引用id
  dir(x)显示某个对象的信息
  dir()无参使用,显示当前的全局对象和局部对象
  type(x)显示对象的类型,没有赋过值的是NoneType

import sys 获得模块
  from sys import exit 获得模块的某个函数

0为假1为真

字符串可以类似char[]
  mysting = '123'
  mystring[0]//为1
  mystring[-1]//为最后一个值3

类似C,如果定义几个同意内容字符常量,那么内存地址都一致
  mystr1='123'
  mystr2='123'
  id(mystr1)==id(mystr2)

else if 为elif表示

没有switch case

打开文件为open(filename,mode),不需要包含库。

**表示乘方。

交换2个值很简单,(x,y)=(y,x)就可以了

-------------------------------------------------------------------------------------
四、对象

a1=a2=111
  a1和a2的引用id相同,即id(a1)==id(a2)或a1 is a2
  这里如果a3=111,那么a3和a1,a2的id相同,估计是查了全部对象。
  如果a1=110或者a1+=1,那么a1的id就改变了。
  如果是复杂一点的,比如列表,就不能配对了。c1=[1,2,3] c2=[1,2,3],2者id不相同。
  列表某项改变,不影响列表的id,但是该项的id就变了。
  c1[1]=4 那么c1[1]的id变了,但是c1的id没变。

对于id的比较,可以直接用is:a=1;c=a;a is c >>True
  常量也同样有id:a=1;id(a)==id(1) >>True 
  a is 1 >>True 
  1 is a>>True
  但是2个常数之间不能用is比较,但是2个字符串可以用is。

cmp 比较2个id的大小,id相同不一样数值相同(如列表),id不同也不代表值不同。
  repr和str的作用在表面基本一致,但是具体差别就是repr还可以用eval恢复,没看明白,存疑。

python没有bool、byte、指针。
  int就是32位,没有short。
  float就是双精度,没有单精度了。

-------------------------------------------------------------------------------------
五、数字


没有i++

整数都是32位。
  长整型无限长度。后加L
  浮点可以用e,如4.3e25
  复数可以用64.1+1.5j 实数real,虚数imag,全部conjugate()

5.51节有个错误,就算是999999*999999,也不会出错,自动转换成了长整型。

~取反 为-(num+1)
  <<左移 >>右移 ^异或

int,long,float,complex用来转换,对复数取2个值的平方和。
  abs绝对值 coerce协调2个数字为同一类型coerce1(1,2L) (1L,2L)
  divmod除法和取余 divmod(10,3) (3,1)
  pow 和**一样,是乘方运算。
  round 把浮点型变成最接近的整数,四舍五入 round(3) 3.0 round(3.49) 3.0 round(3.49,1) 3.5 round(-.5) -1
  math.floor 退一法

整数才能用的函数:hex oct 转换16、8进制 ord 字母转数字 chr 数字转字母

random 随机函数的模块:
  ranint(a,b) a到b的整数,包括a、b,即a<=x<=b
  uniform(a,b) a<=x<b //这个是浮点数
  random()返回[0,1)之间的浮点数
  randrange(1,10)返回1到9的值。
  randrange(1,12,2) 返回从1(1+2*0)到9(1+2*4)的值。
  choice('asd\n')返回一个随机字符
  choice(['abc','dfg','123'])返回其中一个字符串
  sample('asd\n',2)用list返回2个随机字符,顺序可颠倒。不过同样位置上的值不会出现2次,因此第二个参数不能大于字符串的长度。所以有什么允许重复的时候会比较麻烦,但是可以给的第一参数里面带有重复的字符串来解决这个问题。
  如果要随机组成字符串,需要使用string。string.join(random.sample('1234567890asdf',5)).replace(' ','')
shuffle(list)可以打乱list里的元素顺序。

-------------------------------------------------------------------------------------


六、序列

in,not in
  a + b
  a * 4
  a[3]

a=[1,2,3,4] 则 a[0]~a[3]或a[-4]~a[-1]
  len 显示长度
  list 转换seq为列表
  tuple 转换seq为表列
  min,max 返回最大最小
  str 转换为字符串

for循环有个else,如果是循环结束而不是break则执行这个else

%c 字符
  %s 字符串
  %i %d 带符号的十进制
  %u 不带符号的十进制
  %o 八进制
  %x 小写16进制
  %X 大写16进制
  %e %E 乘方记号
  %f 浮点
  %g %G 浮点和乘方比较短的格式


string.find('1231','1') 查找字符返回位置 0

python的字符串不以\0结束。
  >>>str1='\0\0\01'
  >>>str1
  '\x00\x00\x01'
  不过实际长度还是3个元素。
  len(str1)//3
  str1[2]//0x01
  str1.find('1')//-1
  str1.find('\01')//2
  str1.find('\x01')//2

列表list通过append添加新元素
  通过remove以元素的值做参数删除元素,如果有2个一样的值,则删除前一个。如果参数是位置而不是元素的值,按照位置删除用del a[1]
  通过pop弹出最后一个值并删除之。(pop(0)则抛出第一个值并删除之)
  通过extend合并其他列表。
  通过*倍增元素。
  长度可以len([1,2])【书上有误,不可以[1,2].__len__】
  reverse颠倒列表,注意这个不是输出一个颠倒的列表,而是真正把列表颠倒。
  sort排序列表,从小到大。默认是快速排序。
  count一个元素的值,返回在list里有多少个同样的值。
  index比较复杂些,index(4,1,5),查找元素值为4的元素的第一个位置,这个位置必须在[1,5)之间。否则出错,所以使用这个函数当需要try与except包含才可以用,因为它不返回-1。就算只使用第一个参数,如果没有这项,同样是抛出异常,而不是返回-1 。

表列tuple可以添加【tuple1+=(1,1,)】,倍增,但是不能删除和替换。
  但是这里不能加只有一个元素的表列,因为一个元素的表列的属性不是表列,如果要建设单元素的表列,就加个逗号。,如(1,)。
  如:type((1))为int,但是列表不是,如:type([1])为list。
  另,表列中如果有子列表,那么这个子列表是可以修改的,如t=([1,2],3,4) t[0][1]=22 这个是允许的。

str(x) list(x) tuple(x)可以将3者相互转化,不过str(list或tuple),list(tuple),tuple(list)都比较正常,但是将字符串转换为list或者tuple就很麻烦了,因为每个括号、逗号、引号都变成了单独的元素。

list之间可以使用==判断是否相同,这样比较的是具体的值,而不是id。list的id不用,但是具体的值相同,==结果为真。但是用is则为假。

子函数可以返回多个参数,如:
  def foo1():
   return a1,a2,a3
  那么接受就可以写作 x1,x2,x3=foo1() 分别进行接受。感觉这个很不错哦,方便很多呀。

copy模块:一般操作的赋值,都是浅copy,只是把引用ID设置成同一个值。copy.copy()也是浅copy,copy.deepcopy()是深copy,真正的2个对象。

没有字符变量,只有长度为1的字符串。其实字符串就是tuple,不可替换成员。
  对于判断是不是大写字母,数字等,可以import string
  string.uppercase string.lowercase string.letters string.digits
  用not in 和in来判断。
  string里有用的很多,最常用的就是join(把列表变成字符串,第二个参数决定间隔字符),split(返回一个list,为分割后的字符串)。具体见P122

如果在引号前面加上r,则可以取消\开始的特殊效果。
  print '\x66' //f
  print r'\x66' //\x66
  如果是unicode,则使用ur

其他的一些模块:re(匹配字符串),struct(构造发包报文时最常用),c/StringIO(字符串缓冲区对象,行为类似文件),crypt(单向加密编码功能,仅linux使用),rotor(多平台编码解码服务)