怒学Python——第二篇——类型与运算

Python支持5种数据类型,包括数字(numbers)、字符串(string)、列表(list)、元组(tuple)和字典(dictionary)。作为一门动态类型语言,不用去声明一个标示符的类型,使用的时候是什么类型会自动判定。

对于定义好的变量,若不使用该变量,可以用del删除来释放占有的资源,如

var = 10del var

Python的数字(numbers):支持int、long、float和complex,比较简单不给出示例。

Python的字符串(string):如前面所说的可以被多种引号定义,支持[p](获得p位置的字符)、[l:r](获得从l开始到r截止的字符串)、*t(获得t个该字符串链接在一起的字符串)以及+s(获得与s链接后的字符串)方法(methods,为什么用方法呢,与ruby有关,所有对象的.methods可以显示所有能执行的操作,所以我也开始把一个对象能够执行的操作叫做方法),如下示例

s = 'This is a test case.'PRint s[0] #输出s的第一个字符'T'print s[0:4] #输出s的第一个到第四个字符组成的字符串'This'print s*2 #输出两个s字符串链接的新字符串print s + ' Good!' #输出s与' Good!'链接后的字符串

Python的列表(list):用[]来定义,用起来像C++的容器vector,只不过这个容器可以装不同类型的值,同时可以嵌套定义,一个列表里面包含另一个列表,方法与string的类似,如下给出示例

l = ['wyp', 1, 3.14, [2, 'cc']]print l #输出整个lprint l[0] #输出l的第一个元素'wyp'print l[3][0] #输出l的第四个元素的第一个元素2print l[0:3] #输出l的第一个元素到第三个元素print l*2 #输出两个l链接在一起的列表print l+['.'] #输出l与列表['.']链接在一起的列表

Python的元组(tuple):用()来定义,方法与列表相似,唯一区别是不能二次赋值,所以不给出示例。

Python的字典(dictionary):用{}来定义,定义方法像json,用起来像C++的容器map,方法在下给出示例

d = {1:'wyp', 'two':'is', 3.0:'Coder'}
d['four'] = 'like'd[5] = 'farmer'print d #输出整个字典dprint d[1] #输出键为1的值'wyp'print d.keys() #输出所有的键print d.values() #输出所有的值

Python的类型转换:目测用得不多,下面给出示例

int(x) #把x转成int型,直接取整,不管后面的尾数long(x) #把x转成long型,直接取整,不管后面的尾数float(x) #把x转成float型complex(x,y) #创建一个x为实部,y为虚部的复数chr(x) #转成对应ascii码x的字符ord(c) #转成c对应的ascii码unichr(x) #把x转成unicode字符hex(x) #把x转成它的十六进制的字符串oct(x) #把x转成它的八进制的字符串str(x) #把x转换为字符串eval(str) #把一个字符串表达式str的值算出来tuple(s) #把序列型结构的s转成元组list(s) #把序列型结构的s转成列表dict(s) #把序列型结构且每个元素都是二元组的s转成字典

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

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

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

Python的运算方法与C++非常相似,均分为算术运算、比较运算、逻辑运算和位运算,在此基础上加入了成员运算和身份运算,下面给出和C++有出入的示例

算术运算:多出来的运算符有**和//,因此多出了**=和//=给出示例

a ** b #即a^b,a的b次方a // b #先a/b然后再直接取整

比较运算:多出来的运算符是"<>",与"!="功能一样,所以就不给出示例

逻辑运算:这里有点不同,逻辑运算全部用英文表示了,就是与(and)、或(or)和非(not),用法一样就不给出示例了

位运算:与C++相同

成员运算:运算符为in和not in,以in为例如果一个元素在序列里就是true,否则false,另外一个就是取反,下面给出示例

t = [1, 2, 3, 4]1 in t #返回true1 not in t #返回false0 in t #返回false0 not in t #返回true

身份运算:运算符为is和not is,即判断两个变量是否为同一个存储单元,在这里发现一个python的小细节,它的0~256这些整数全部都是已经存放在内存中的,而其他的都是在定义的时候直接分配新内存,下面给出示例

a = -1b = -1a is b #值为false,这里发现-1不是python预先存放在内存中的a += 1b += 1while (a is b): #在256之前都为true
a += 1
b += 1 print str(a) + ', ' + str(b) + '\n'

以上就是怒学Python——第二篇——类型与运算的内容,更多相关内容请关注龙方网络(www.yzlfxy.com)!

郑重声明:本文版权包含图片归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们(delete@yzlfxy.com)修改或删除,多谢。

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

留言与评论(共有 0 条评论)
昵称:
匿名发表
   
验证码: