基础数据类型初始。

数字:int 12,3,45 + - * / **    int: bit_lenth()转化为2进制的最小位数。
% 取余数
ps:type()
字符串转化成数字:int(str) 条件:str必须是数字组成的。
数字转化成字符串:str(int)
字符串:str,python当中凡是用引号引起来的都是字符串。
可相加:字符串的拼接。
可相乘:str * int
bool:布尔值。 True False。bool(int)可以转换为 T or F 。0为T;非0为F

str---->bool :bool(str); s = " " (空字符)---> False;  s = "1"(非空字符)---> True

ig = 0;st ='';l = {};s=[];se=set()

#bool值都为0

 

s = input("")

if s:

  pass

else:

  pass

 

字符串的切片(顾头不顾尾)

[首:尾:步长]  步长为1(正向取)一般省略;步长为-1(反向取);步长为2(隔一个取) 

s="ABCDKSDFESF"

s1=s[:]   s1=s[0:]   ----> s1="ABCDKSDFESF"  

s2 =s[::-1] s2=s[-1::-1]  -----> s2="FSEFDSKDCBA"

字符串常用方法

s ="asDSswWss"
s1 = s.upper()  upper() 全部大写
s2 = s.lower()   lower()  全部小写
print(s1,s2)    
#captalize,swapcase,title
print(name.capitalize()) #首字母大写
print(name.swapcase()) #大小写翻转
msg='taibai say hi'
print(msg.title()) #每个单词的首字母大写

# 内同居中,总长度,空白处填充*
ret2 = a1.center(20,"*")  
print(ret2)

#数字符串中的元素出现的个数。
# ret3 = a1.count("a",0,4) # 可切片
# print(ret3)


a4 = "dkfjdkfasf54"
#startswith 判断是否以...开头
#endswith 判断是否以...结尾
# ret4 = a4.endswith('jdk',3,6)  # 顾头不顾尾
# print(ret4)  # 返回的是布尔值
# ret5 = a4.startswith("kfj",1,4)
# print(ret5)

#寻找字符串中的元素是否存在
# ret6 = a4.find("fjdk",1,6)
# print(ret6)  # 返回的找到的元素的索引,如果找不到返回-1

# ret61 = a4.index("fjdk",4,6)
# print(ret61) # 返回的找到的元素的索引,找不到会报错。

#不写默认按照空格分割 #split 以什么分割,最终形成一个列表此列表不含有这个分割的元素。split可以把str 转换为 list. # ret9 = 'title,Tilte,atre,'.split(',',次数)#不写次数,默认全部. # print(ret9) # ret91 = 'title,Tilte,atre,'.rsplit('t',1) rsplit(从右开始分割) # print(ret91)


#join 可以把list(里面要为str) 转换为 str
s=["alse","2","6","9"]
s1 = '+'.join(s)
print(s1)
alse+2+6+9 #format的三种玩法 格式化输出 res='{} {} {}'.format('egon',18,'male') res='{1} {0} {1}'.format('egon',18,'male') res='{name} {age} {sex}'.format(sex='male',name='egon',age=18) #strip strip() 括号里面有什么就可以删什么,默认删除空格和\n(换行符)
#该方法只能删除开头或是结尾的字符,不能删除中间部分的字符 name=' *barry** .' print(name.strip('*')) print(name.strip('* .')) print(name.lstrip('*')) rstrip(从右开始删除) print(name.rstrip('*')) lstrip(从左开始删除) #replace(old,new,次数) name='alex say :i have one tesla,my name is alex' print(name.replace('alex','SB',1)) #####is系列 name='taibai123' print(name.isalnum()) #字符串由字母或数字组成 print(name.isalpha()) #字符串只由字母组成 print(name.isdigit()) #字符串只由数字组成 

print(name.isspace()) #字符串只由空格组成

while。

while 条件:
循环体
无限循环。
终止循环:1,改变条件,使其不成立。2,break

while 1:                while True :

  pass      比             pass           的效率高

while else

当while循环被break打断市,就不会执行else的结果。

若没有break,则结束循环后最后会执行else语句。

continue :跳过本次循环,继续下一次的循环。

变量

变量:就是将一些运算的中间结果暂存到内存中,以便后续代码调用。
1,必须由数字,字母,下划线任意组合,且不能数字开头。
2,不能是python中的关键字。
['and', 'as', 'assert', 'break', 'class', 'continue',
'def', 'del', 'elif', 'else', 'except', 'exec',
'finally', 'for', 'from', 'global', 'if', 'import',
'in', 'is', 'lambda', 'not', 'or', 'pass', 'print',
'raise', 'return', 'try', 'while', 'with', 'yield']
3,变量具有可描述性。
4,不能是中文。
7,常量。
一直不变的量。 π
BIR_OF_CHINA = 1949

 

注释

方便自己方便他人理解代码。
单行注释:#
多行注释:'''被注释内容''' """被注释内容"""  ("""可以输出位置不变的多行str)

用户交互。input

1,等待输入,
2,将你输入的内容赋值给了前面变量。
3,input出来的数据类型全部是str

格式化输出

%为占位符,s,d为替换的类型 s(str);d(digit)  

用法:'%s,%d'%(name,age)

%%只是在格式化输出中显示%

dic = {'name':'zzz','age':24}
a = 'name:%s,age:%d' % (dic['name'],dic['age'])
print(a)

  

编码

最早的密码本为ascii码 , ascii码覆盖了英文字母大小写,以及特殊字符,数字。ascii码储存的实际上是2进制(010101010101)。用一个字节表示,一个字节为8位。

ascii码为了解决全球化的文字问题,创建了一个万国码,unicode最早一个字符是两个字节,16位表示;现在是 一个字符(中文还是英文)用四个字节(32位)表示。

Unicode 升级 utf-8 utf-16 utf-32
8位 = 1字节bytes
utf-8 一个字符最少用8位去表示,

英文用8位                              一个字节
欧洲文字用16位去表示          两个字节
中文用24 位去表示                 三个字节
utf-16 一个字符最少用16位去表示

gbk 是中国人自己发明的,一个英文用一个字节;一个中文用两个字节(16位)去表示,只能用于中文和ascii码中的文字。

1bit     8bit = 1bytes
1byte  1024byte = 1KB
1KB    1024kb = 1MB
1MB   1024MB = 1GB
1GB    1024GB = 1TB0

编码的注意事项:1,各个编码之间的二进制是不能识别的,容易产生乱码。

2,文件的传输和存储只能是bytes类型,不是unicode. bytes类型包含常用的 utf-8,gbk,ascill码等。

str 在内存中是用unicode编码。要想文件的传输和存储只能将str--------->bytes ,用encode('utf-8')编码.

对于英文来说,  str :  表现的形式为  a = 'alex' ,  编码的方式为 unicode;

     bytes  :  表现的形式为   a =b'alex' , 编码的方式为  utf-8,gbk...

对于中文来说,  str :  表现的形式为  a = '中国' ,  编码的方式为 unicode;

     bytes  :  表现的形式为   a =b'\xe4\xb8\xad\xe5\x9b\xbd', 编码的方式为  utf-8,gbk...

s = '中国'
s1 = s.encode('utf-8')
print(s1)  #b'\xe4\xb8\xad\xe5\x9b\xbd'

s = '中国'
s1 = s.encode('gbk')
print(s1)   #b'\xd6\xd0\xb9\xfa' 

 逻辑运算符

非零数为True; 0为False

优先级:()> not>and>or,同一优先级从左往右计算。

not:返回表达式结果的“相反的值”

T and fun()  ,   执行后面fun()

F and fun()  ,   执行前面

F or fun()   ,    执行后面fun()

T or fun()  ,    执行前面

总结:or 与 and 情况相反

print(1>2 and 3 or 4 and 3 <2)
print(2 or 1<3 and 2)
False
2  

 注意:不要在列表和字典的循环中删除列表或者是字典里面的元素,对于列表来说,不会报错但是删除的元素会有变化,但是字典会报错。

 

lis = [11,22,33,44,55]

for i in range(len(lis)):
    # print(i)
    if i %2 == 1:
        # del lis[i]
        lis.pop(i)
        # print(lis)
print(lis)
#该结果应当是 [11,33,55]
#但是输出的结果为[11, 33, 44] ; 因为每次删除列表中的元素,在下一次循环中,
# 该列表中的元素的index会发生改变
正确的方法:

#将列表中的index为奇数的值删去

lis = [11,22,33,44,55,66,77,88]
j=0
for i in range(len(lis)):
if i % 2 == 1:
if i >1:
j=j+1
i= i-j
del lis[i]

print(lis)

 

 

#需要将该字典中的K值带K的键值对删去


dic1 ={'k1':'s','k2':'23','s':'88','w':'22'}

for i in dic1:
    if 'k' in i:
        dic1.pop(i)

print(dic1)

#RuntimeError: dictionary changed size during iteration  


dic1 ={'k1':'s','k2':'23','s':'88','w':'22'}
l =[]
for i in dic1:
    if 'k' in i:
        l.append(i)
for j in l:
    dic1.pop(j)
print(dic1)

#{'s': '88', 'w': '22'}

列表:是以[]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型

li = [1,'a','b',2,3,'a']
# li.insert(0,55) #按照索引去增加
# print(li)
#
# li.append('aaa') #增加到最后
# li.append([1,2,3]) #增加到最后
# print(li)
#
# li.extend(['q,a,w']) #迭代的去增
# li.extend(['q,a,w','aaa'])
# li.extend('a')
# li.extend('abc')
# li.extend('a,b,c')
# print(li)

 删 

# l1 = li.pop(1) #按照位置去删除,有返回值
# print(l1)

# del li[1:3] #按照位置去删除,也可切片删除没有返回值。
# print(li)

# li.remove('a') #按照元素去删除
# print(li)

# li.clear() #清空列表

 改 

# 改
# li = [1,'a','b',2,3,'a']
# li[1] = 'dfasdfas'
# print(li)
# li[1:3] = ['a','b']
# print(li)

index(方法用于从列表中找出某个值第一个匹配项的索引位置)# 但是对于重复的元素来说 index 只能返回相同元素的一个元素的索引位置:

l=[11,2,3,3,7,9,11,2]
for i in l:
	# 对于Index来说 元素相同 就 返回第一个元素的索引;
	n = l.index(i)
	print("index:",n,"元素",i)
# index: 0 元素 11
# index: 1 元素 2
# index: 2 元素 3
# index: 2 元素 3
# index: 4 元素 7
# index: 5 元素 9
# index: 0 元素 11
# index: 1 元素 2

  

count(数)(方法统计某个元素在列表中出现的次数)。

sort (方法用于在原位置对列表进行排序)。如果列表中为非数字字符串,也可以排序,是按照第一个元素的ascii码来排序的。

li = ["曾辉","sss","wwww"]
li.sort()

  

 reverse (方法将列表中的元素反向存放)。

a = [2,1,3,4,5]
a.sort()# 他没有返回值,所以只能打印a
print(a)
a.reverse()#他也没有返回值,所以只能打印a
 print(a)

元组被称为只读列表,即数据可以被查询,但不能被修改,所以,字符串的切片操作同样适用于元组;但是元组的儿子不能改,但是孙子可能可以改变。如果元组里面只有一个元素,并且不加‘,’(逗号),则该元素是什么类型就是什么类型的

 

tup1 = ([1])
tup2 = ([1],)
print(tup1,type(tup1))  #[1] <class 'list'>
print(tup2,type(tup2))   #([1],) <class 'tuple'>

 

tu=(1,3,6,["asa",2,6],"sss")
tu[3][0] = "ss"
print(tu)

(1, 3, 6, ['ss', 2, 6], 'sss') 

range  实际是按照数字顺序排列的列表,也可切片,有步长。

for i in range(0,10,1):
    print(i)
for i in range(0,10,-1):
    print(i)
for i in range(10,0,-1):
    print(i)
for i in range(10,-1):
    print(i)

0,1,2,3,4,5,6,7,8,9

什么都不输出也不报错

10,9,8,7,6,5,4,3,2,1

什么都不输出也不报错

 dict (字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据。)

数据类型划分:可变数据类型,不可变数据类型
不可变数据类型:元组,bool int str 可哈希
可变数据类型:list,dict set 不可哈希
dict key 必须是不可变数据类型,可哈希,
value:任意数据类型。
dict 优点:二分查找去查询
存储大量的关系型数据
特点:无序的

 

dic1 = {'age': 18, 'name': 'jin', 'sex': 'male'}

dic1['age'] = 12 #若存在相同的K值,则会改变value(覆盖)
dic1['height'] = 175 #若没有K值,则会直接添加
print(dic1)

dic1.setdefault('age') #若存在相同的K值,则value不会覆盖
dic1.setdefault('height',175) #若没有K值,则会直接添加
print(dic1)

 

删  

dic1 = {'age': 18, 'name': 'jin', 'sex': 'male'}

dic1.pop("age"),有返回值,返回的是value
print(dic1.pop('二哥',None))  #若删除找不到的K值,必须添加返回值,不然会报错
print(dic1.popitem()) #返回值为一个元组(K,V)
del dic1['age']
del dic1['二哥']  #若删除找不到的K值,会报错
del dic1
dic1.clear()

print(dic1)

dic1 = {'age': 18, 'name': 'jin', 'sex': 'male'}
dic1['age'] = 16
#update  相同K的value值覆盖,没有的K-v 添加
dic = {"name":"jin","age":18,"sex":"male"}
dic2 = {"name":"alex","weight":75}    
dic2.update(dic) 
print(dic2)

dic = {"name":"jin","age":18,"sex":"male"}

for i in dic.values():
    print(i)
for i in dic: #for i in dic.kes()
    print(i)
for i in dic.items(): #返回的是一个元组(K,V)
    print(i)
for i,j in dic.items():
    print(i,j)
dic = {"name":"jin","age":18,"sex":"male"}

v1 = dic['weight']  #报错
print(v1)
print(dic.get('weight',0))  #用get 找不到k不会报错,则会返回0

 

enumerate:枚举,对于一个可迭代的(iterable)/可遍历的对象(如列表、字符串)
enumerate将其组成一个索引序列,利用它可以同时获得索引和值。(索引,值)
li = ['alex','银角']
for i in enumerate(li):   #索引的起始位置默认是0
    print(i) #    (0, 'alex'),(1, '银角')
for index,name in enumerate(li,1):  #索引的起始位置变为1
    print(index,name) #1 alex;2 银角
for index, name in enumerate(li, 100):  # 起始位置默认是0,可更改
    print(index, name) #100 alex;101 银角

dic = {'name':'alex','age':25,'sex':'nan'}

for i in enumerate(dic):  #字典默认循环遍历K
    print(i)  #(0, 'name');(1, 'age');(2, 'sex')

for j in enumerate(dic.items()):
    print(j)  # (0, ('name', 'alex')) 

集合(set)

集合本身是可变类型(不可哈希),不能作为字典的键(K)。但是它里面的元素是可哈希的(不可变类型)

集合是无序的,不重复的数据集合。集合最重要的两点:

  1.去重,把一个列表变成集合,就自动去重了。

  2.关系测试,测试两组数据之前的交集、差集、并集等关系。

1.集合的创建

st1 = set({1,2,3,'abc'})
print(st1,type(st1))

st2 = {1,2,3,'abc'}
print(st2,type(st2))

2集合的增

st2 = {1,2,3,'abc'}

st2.add('qaz')

st2.update('abc')
st2.update('老师')  #update 为可迭代增加
print(st2)

3.集合的删

st2 = {1,2,3,'abc'}

print(st2.pop())   #随机删除 ; 并且有返回值
# st2.remove('abc')  #若找不到删除元素的,会报错
print(st2)
st2 = {1,2,3,'abc'}

# del st2     #删除集合  
st2.clear()   #清空集合;空的集合的变现形式为set()
print(st2)

4.集合的查

st2 = {1,2,3,'abc'}

for i in st2:
    print(i)

5,集合的其他操作:

  1交集。(&  或者 intersection)   

st2 = {1,2,3,4,5,6}
st1 = {5,6,7,8,9,10}
# print(st2 & st1)
# print(st2.intersection(st1)) 

  2并集。(| 或者 union)

st2 = {1,2,3,4,5,6}
st1 = {5,6,7,8,9,10}

# print(st1 | st2 )
# print(st2.union(st1))

  3差集。(- 或者 difference)

st2 = {1,2,3,4,5,6}
st1 = {5,6,7,8,9,10}

# print(st1 - st2)  #被减数(前)相对于减数(后)的特有的部分
# print(st2.difference(st1))

  4反交集。 (^ 或者 symmetric_difference)

st2 = {1,2,3,4,5,6}
st1 = {5,6,7,8,9,10}

print(st2 ^ st1)

  5子集与超集

st2 = {1,2,3,4,5,6}
st1 = {5,6}

print( st1 < st2)  #返回的是pool值
print(st1.issubset(st2))  #st1是st2的子集

print(st2.issuperset(st1))
print( st2 > st1)   # 这两个相同,都是说明set2是set1超集。

 

6.frozenset不可变集合,让集合变成不可变类型。 #只读

s = frozenset('barry')
print(s,type(s))
 #返回值为:frozenset({'y', 'a', 'b', 'r'}) <class 'frozenset'>


posted on 2019-01-07 14:42  小辉python  阅读(323)  评论(0编辑  收藏  举报