欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

python学习杂记(二)

程序员文章站 2024-03-13 15:47:15
...
[size=medium] 今天是周末,继续学习python,在看一本《Python核心编程(第二版)》的pdf电子书。看了前面6章,总结下看到的一些知识[/size]

[size=large][b]一、python对象:[/b][/size]

[size=medium][b]1.python里的标准类型:[/b][/size]

[size=medium] python中的标准类型有五个,分别是:数字,字符串,元组,列表,字典。其中这几个标准类型中,数字,字符串,元组是不可变类型,列表,字典是可变类型。通过使用id()函数可以很容易地验证以上内容。如:[/size]

a = u"abcdef";
first_id = id(a);
a = u"abcde";
second_id = id(a);
print first_id == second_id;# False

[size=medium][b]2.python里的type()函数和isinstance()函数[/b][/size]

[size=medium] type()函数的返回结果是一个tpye类型对象(注意:type也是一种类型),可以使用tpye方法来判断两个对象是否是同一个类型的对象
isinstance()函数接受两个参数,第一个是要判断的对象obj,第二个参数是类型名称,可以使一个元组,返回值是布尔值
在代码中,我们可以使用以下的方式对变量的类型进行判断[/size]

# type()函数
print type(10);#输入的内容是<type 'int'>
print type(type(10););#输入的内容是<type 'type'>

# 判断一个对象是否我们需要的类型
def useType(obj):
# 这里除了使用type(0)的做比较,也可以引入tpyes模块,使用types.IntType代替
# 同理,type(0.0)也可以用types.FloatType代替,其它类型不在累述
if type(obj) == type(0) or type(obj) == type(0.0):
return True;
else:
return False;
# 使用isinstance方法完成同样的操作
def useIstance(obj):
if isinstance(obj,(int,float)):
return True;
else:
return False;

[size=large][b]二、数字和字符串[/b][/size]

[size=medium][b]1.数字[/b][/size]

[size=medium] 在python中,整形包括int型和long型,但是我们不需要考虑溢出的问题,在整形数据大小超出范围以后,python会帮我们转换成长整型。如果想声明一个长整行类型的数,只需要加上L即可。
python的浮点型数float是双精度浮点型,即类似于java中的double类型。
python中还有一种类型就是复数,a+bj,a是实数,b是虚数
python中支持两个以上表达式的大小比较,比较顺序是从左到右,各个条件用and连起来[/size]

print 1<2<3!=4<5;# True
# 等价于
print 1<2 and 2<3 and 3!=4 and 4<5;

[size=medium] **两个乘号是幂运算,2**3就是2的三次方。进制转换函数oct()用于把一个整数转换为八进制数,八进制整数以0开头,hex()把一个整数转换为十六进制数,十六进制整数是0x或者是0X开头。[/size]

[size=medium][b]2.字符串[/b][/size]
[size=medium] 可以通过索引找到对应的字符,索引值可以使正向索引,从0开始到len-1,也可以是反向索引,从-1到-(len-1)。我们可以通过索引取得某个位置的字符串,但是因为字符串是不可改变类型,我们不能改变字符串中某个位置的值,否则会出错。
截取某部分字符串的时候使用切片操作符[start:stop:step],当只有第一个参数时就表示获取单个下标的字符串。
判断一个字符串是不是另一个字符串的子串,可以使用in 和not in或者是find()和rfind()函数来进行判断(找不到返回-1)。[/size]

v = u"abcdefg";
print v[0];# 输出a

# 试着改变某个字符串某个位置的值
v[2] = "a";# 出错

print v[0:4];# abcd
print v[0:4:2]; # ac

[size=medium] 字符串的格式化输出,可以使用%来完成,常用的有:%s表示是字符串,%d表示是整型,%f表示是浮点型,%e表示输出科学计数法表示的数,%%表示输出一个%号。在使用的时候可以用元组参数或者是字典参数做转换。[/size]

# 元组
print "string : %s,int : %d,float : %f,e : %e,100 percent : 100%%" %("ss",1,1.0,1231235.34235);
# 字典
print "string : %(s_key)s,int : %(i_key)d,float : %(f_key)f,e : %(e_key)e,100 percent : 100%%" %{"s_key":"ss","i_key":1,"f_key":1.0,"e_key":13123.121};

[size=medium] 除了使用%号完成格式化输出,还有更简单的方式,就是使用字符串模板。使用字符串模板要引入string的Template类[/size]

# 使用模板类
v = Template("This is a template model,${h} ${w}!!");
print v.substitute(h="hello",w="world");

[size=medium] 在python中如果你想输出"\n"这些的字符串,直接输出是不行的,它会变成一个换行符,"\t"会变成一个Tab符,要输出它们,只需要在字符串的开始位置加上r或者是R就能输出原始字符而不会进行转义。
string模块中,可以很容易的获取由字母组成的字符串,有大写形式的string.uppercase,小写形式的string.lowercase,大小写都包含的string.letters以及数字string.digits四种字符串。chr()函数接收一个整型数,返回一个对应的字符,ord()是与之配对的函数,接收一个字符串参数,返回该字符串对应的ASCII值或者是Unicode编码值。另外字符串复制可以使用*运算符, "x"*3得到的结果就是"xxx"[/size]