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
long(长整型)
  跟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 = (1122334455)
ages = tuple((1122334455))
基本操作:

 

  • 索引
  • 切片
  • 循环
  • 长度
  • 包含
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
 
= 60            # 60 = 0011 1100
= 13            # 13 = 0000 1101
= 0
 
= a & b;        # 12 = 0000 1100
print "Line 1 - Value of c is ", c
 
= a | b;        # 61 = 0011 1101
print "Line 2 - Value of c is ", c
 
= a ^ b;        # 49 = 0011 0001
print "Line 3 - Value of c is ", c
 
= ~a;           # -61 = 1100 0011
print "Line 4 - Value of c is ", c
 
= a << 2;       # 240 = 1111 0000
print "Line 5 - Value of c is ", 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
 
posted @ 2017-01-03 07:45  200六  阅读(98)  评论(0编辑  收藏  举报