python 之路学习总结
1、数字
2 是一个整数的例子。
长整数 不过是大一些的整数。
3.23和52.3E-4是浮点数的例子。E标记表示10的幂。在这里,52.3E-4表示52.3 * 10-4。
(-5+4j)和(2.3-4.6j)是复数的例子。
int(整型)
在32位机器上,整数的位数为32位,取值范围为-2**31~2**31-1,即-2147483648~2147483647
在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807
在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807
long(长整型)
跟C语言不同,Python的长整数没有指定位宽,即:Python没有限制长整数数值的大小,但实际上由于机器内存有限,我们使用的长整数数值不可能无限大。
注意,自从Python2.2起,如果整数发生溢出,Python会自动将整数数据转换为长整数,所以如今在长整数数据后面不加字母L也不会导致严重后果了。
float(浮点型)
浮点数用来处理实数,即带有小数的数字。类似于C语言中的double类型,占8个字节(64位),其中52位表示底,11位表示指数,剩下的一位表示符号。
complex(复数)
复数由实数部分和虚数部分组成,一般形式为x+yj,其中的x是复数的实数部分,y是复数的虚数部分,这里的x和y都是实数。
跟C语言不同,Python的长整数没有指定位宽,即:Python没有限制长整数数值的大小,但实际上由于机器内存有限,我们使用的长整数数值不可能无限大。
注意,自从Python2.2起,如果整数发生溢出,Python会自动将整数数据转换为长整数,所以如今在长整数数据后面不加字母L也不会导致严重后果了。
float(浮点型)
浮点数用来处理实数,即带有小数的数字。类似于C语言中的double类型,占8个字节(64位),其中52位表示底,11位表示指数,剩下的一位表示符号。
complex(复数)
复数由实数部分和虚数部分组成,一般形式为x+yj,其中的x是复数的实数部分,y是复数的虚数部分,这里的x和y都是实数。
注:Python中存在小数字池:-5 ~ 257
2、布尔值
真或假
1 或 0
3、字符串
"hello world"
万恶的字符串拼接:
python中的字符串在C语言中体现为是一个字符数组,每次创建字符串时候需要在内存中开辟一块连续的空,并且一旦需要修改字符串的话,就需要再次开辟空间,万恶的+号每出现一次就会在内从中重新开辟一块空间。
字符串格式化
1
2
3
4
|
name = "alex" print "i am %s " % name #输出: i am alex |
PS: 字符串是 %s;整数 %d;浮点数%f
字符串常用功能:username=input("姓名:") if username.strip()=="erfei":#strip()字符串操作,退去字符串两边空格 print("很好") name="123,456,789,741" name2=name.split(",")#分割字符串,可以指定按任意符号分割。直接分割成了一个列表 name3="|".join(name2)#合并字符串,可任意指定按任意符号合并。 print(name2,name3) name="erfei hh" if " "in name:#判断字符串中存在不存在空格 print("有空格") print(name.capitalize())#将字符串首字母改成大写 msg="hello,{name}" msg2=msg.format(name="erfei")#格式化字符串的方法之一, name1="hhhhh{0},hhh{1}" print(name1.format("erfei",22)) print(msg2) name="erfei hh" print(name[0:5])#字符串的切片 name="erfei hh" print(name[0:5])#字符串的切片 print(name.center(40,"-"))#共生成40个字符,不够两边填充 - 均匀填充 print(name.find("e"))#找到字符串中的e 返回e的下标。找不到返回-1 age=input("输入年龄:") if age.isdigit():#判断输入的是不是一个数字,返回是,与否 age=int(age) print(age) else: print("输入的年龄不合法,请输入正确的年龄。。") name2="erfei,3ll" print(name2.isalnum())#判断字符串是否包含空格和标点符号,返回是与否 print(name2.endswith("311"))#判断字符串是不是以指定字符结尾,返回是与否 print(name2.startswith("er"))#判断字符串是不是以指定字符开头,返回是与否 print(name2.upper())#将字符串中所有字符改成大写 print(name2.lower())#将字符串中所有字符改成小写 dir(os)查看类包含的方法 help(os)查看帮助 dir()可以直接查看当前已经定义的类、方法、或者变量名。 name="1234567890" l=name.replace("2","222")#用一段字符串替换另一段字符串 print(l)
- 移除空白
- 分割
- 长度
- 索引
- 切片
4、列表
创建列表:
1
2
3
|
name_list = [ 'alex' , 'seven' , 'eric' ] 或 name_list = list ([ 'alex' , 'seven' , 'eric' ]) |
基本操作:
name=[1,5,9,3,2,4,7,9,5,6,2,9,9,8,55,5,5,5,2,6,9,9,89,4,22,2,999,2,2,2,54] name2=[1,3,5,7,9] name.append(9999)#在列表中追加元素 name.remove(1)#删除一个元素 name.insert(5,123456)#在指定位置插入元素 name.pop(10)#删除指定元素 name1=name[0:6:2]#取出列表中的元素与步长 name[9]=10010#改变 指定的元素 position_of_elie=name.index(9)#找到9的下标也就是说第几个是9 #name.clear()清空这个列表 name.extend(name2)#合并两个列表,扩展进来一个新的列表 #name.reverse()#反转整个列表 name.sort()#排序整个列表 print(name) print(name1) print(position_of_elie) name=[1,5,9,3,2,4,7,9,5,6,2,9,9,8,55,5,5,5,2,6,9,9,89,4,22,2,999,2,2,2,54] if 9 in name: name_1=name.count(9)#判断列表有几个9这个元素 print(name_1) print("9 is in name")#判断列表有没有9这个元素
- 索引
- 切片
- 追加
- 删除
- 长度
- 切片
- 循环
- 包含
5、元祖
创建元祖:
1
2
3
|
ages = ( 11 , 22 , 33 , 44 , 55 ) 或 ages = tuple (( 11 , 22 , 33 , 44 , 55 )) |
基本操作:
- 索引
- 切片
- 循环
- 长度
- 包含
6、字典(无序)
创建字典:
1
2
3
|
person = { "name" : "mr.wu" , 'age' : 18 } 或 person = dict ({ "name" : "mr.wu" , 'age' : 18 }) |
常用操作:
id_dd={1001:{ "name":"二飞", "age":23, "xingbie":"男"}, 1002:{ "name":"小傻", "age":55, "xingbie":"男" }}#生成了一个字典,字典的键是唯一的,字典是无序的 haoma=id_dd[1001]#通过指定的键取出对应的值 id_dd[1001]["age"]=25#改变指定里的值 id_dd[1001]["qq"]=963469010#在字典中加入新的值, del id_dd[1002]["name"] #删除列表中元素1 id_dd[1002].pop("age") #删除列表中元素2 k=id_dd.get(1001)#获取值如果不存在不会报错推荐使用,类似于id_dd[1001] print(haoma) print(id_dd) print(k) id_dd={1001:{ "name":"二飞", "age":23, "xingbie":"男"}, 1002:{ "name":"小傻", "age":55, "xingbie":"男" }}#生成了一个列表列表的键是唯一的,字典是无序的 dict1={"name":1111111, 1002:{ "name":"小傻", "age":5, "xingbie":"男" }} id_dd.update(dict1)#去更新一个列表吧列表2更新到列表1里面 l=id_dd.items()#吧字典转换成一个元组,一般数据量大不要这么干因为特别慢 k=id_dd.values()#获取所有的v,所有的值 a=id_dd.keys()#获取所有的keys,所有的键 #q=id_dd.has_key(1001)#查看字典中是否存在该键2.0的写法3.0不好使。 1002 in id_dd #查看字典中是否存在该键, print(id_dd) print(l) print(k) print(a) id_dd={1001:{ "name":"二飞", "age":23, "xingbie":"男"}, 1002:{ "name":"小傻", "age":55, "xingbie":"男" }}#生成了一个列表列表的键是唯一的,字典是无序的 dict1={"name":1111111, 1002:{ "name":"小傻", "age":5, "xingbie":"男" }} l=id_dd.setdefault(1003,"hhhhh")#获取一个key,如果不存在就创建一个他的返回值是加入的值,或取出的值 print(dict.fromkeys([1,2,3,4,5,6],"fffffff"))#吧列表里每一个值当成一个键来生成一个字典,据说这里存在一个坑哦, #id_dd.popitem()#随机删除一个数据 print(l) print(id_dd) for k,v in id_dd.items():#循环一个字典效率底 print(k,v) for key in id_dd: print(key,id_dd[key])#高效的循环
- 索引
- 新增
- 删除
- 键、值、键值对
- 循环
- 长度
PS:循环,range,continue 和 break
十一、运算
算数运算:
比较运算:
赋值运算:
逻辑运算:
成员运算:
身份运算:
位运算:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
#!/usr/bin/python a = 60 # 60 = 0011 1100 b = 13 # 13 = 0000 1101 c = 0 c = a & b; # 12 = 0000 1100 print "Line 1 - Value of c is " , c c = a | b; # 61 = 0011 1101 print "Line 2 - Value of c is " , c c = a ^ b; # 49 = 0011 0001 print "Line 3 - Value of c is " , c c = ~a; # -61 = 1100 0011 print "Line 4 - Value of c is " , c c = a << 2 ; # 240 = 1111 0000 print "Line 5 - Value of c is " , c c = a >> 2 ; # 15 = 0000 1111 print "Line 6 - Value of c is " , c |
运算符优先级:
十二while循环:
这是一个可以循环到天荒地老的循环: 如果while 为真就一直循环下去: count=0 while True: count+=1 if count>50 and count<60: continue print("你是风儿他说啥。。。。。", count) if count >100: print("去你的风儿和啥。。。。。") break
1
|
|
1
|
|