python基础语法 - 数据类型
Python的数据类型:
- Numbers(数字)
- String(字符串)
- List(列表)
- Tuple(元组)
- Dictionary(字典)
- Set(集合)
Numbers(数字)
数字类型分为:整数,浮点数,复数
运算:
+ - * / 加减乘除
** 平方
String(字符串)
字符串就是一系列字符,在Python中,用引号括起来的都是字符串,其中的引号可以使单引号,也可以是双引号。
1. 创建字符串
"This is a string." 'This is also a string.'
2.基本操作方法
#重复输出字符串 print('hello'*2) #切片,通过索引获取字符串中字符 print('helloworld'[2:]) #成员运算符,返回True或False print('el' in 'hello') #格式字符串 name = 'Hans' print('Hi,%s'%a) #字符串拼接,+号可以直接拼接(低效) a='123' b='abc' string=''.join([a,b]) print(string) # 删除空白: string.rstrip() #删除字符串末尾的空格 string.lstrip() #删除字符串开头的空格 string.strip() #删除字符串两端的空格
3.大小写操作
# 字符串大小写相关操作 string.capitalize() #把字符串的第一个字符大写 string.title() #所有单词首字母转换为大写 string.swapcase() #转换 string 中的大小写 string.lower() #转换 string 中的大写字符为小写 string.upper() #转换 string 中的小写字符为大写
4.字符串判断
string.isdigit() #检测字符串是否只由数字组成 string.isalpha() #检测字符串是否只由字母组成 string.isspace() #检测字符串是否只由空格组成 string.isalnum() #检测字符串是否由字母和数字组成 string.islower() #检测字符串是否由小写字母组成 string.isupper() #检测字符串是否由大写字母组成 string.isnumeric() #检测字符串是否只由数字组成,针对unicode对象 string.isdecimal() #检查字符串是否只包含十进制字符,针对unicode对象 string.istitle() #检测字符串中所有的单词拼写首字母是否为大写 string.endswith(obj, beg=0, end=len(string)) #判断字符串是否以指定后缀结尾 string.startswith(obj, beg=0,end=len(string)) #检查字符串是否是以指定子字符串开头
# string.center(width) 返回一个原字符串居中,并使用空格填充至长度 width 的新字符串 # string.count(str, beg=0, end=len(string)) 返回 str 在 string 里面出现的次数,如果 beg 或者 end 指定则返回指定范围内 str 出现的次数 # string.decode(encoding='UTF-8', errors='strict') 以 encoding 指定的编码格式解码 string,如果出错默认报一个 ValueError 的 异 常 , 除 非 errors 指 定 的 是 'ignore' 或 者'replace' # string.encode(encoding='UTF-8', errors='strict') 以 encoding 指定的编码格式编码 string,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace' # string.expandtabs(tabsize=8) 把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8。 # string.find(str, beg=0, end=len(string)) 检测 str 是否包含在 string 中,如果 beg 和 end 指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回-1 # string.index(str, beg=0, end=len(string)) 跟find()方法一样,只不过如果str不在 string中会报一个异常. # string.join(seq) 以 string 作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串 # string.ljust(width) 返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串 # string.maketrans(intab, outtab]) maketrans() 方法用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。 # max(str) 返回字符串 str 中最大的字母。 # min(str) 返回字符串 str 中最小的字母。 # string.partition(str) 有点像 find()和 split()的结合体,从 str 出现的第一个位置起,把 字 符 串 string 分 成 一 个 3 元 素 的 元 组 (string_pre_str,str,string_post_str),如果 string 中不包含str 则 string_pre_str == string. # string.replace(str1, str2, num=string.count(str1)) 把 string 中的 str1 替换成 str2,如果 num 指定,则替换不超过 num 次. # string.rfind(str, beg=0,end=len(string) ) 类似于 find()函数,不过是从右边开始查找. # string.rindex( str, beg=0,end=len(string)) 类似于 index(),不过是从右边开始. # string.rjust(width) 返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串 # string.rpartition(str) 类似于 partition()函数,不过是从右边开始查找. # string.split(str="", num=string.count(str)) 以 str 为分隔符切片 string,如果 num有指定值,则仅分隔 num 个子字符串 # string.splitlines(num=string.count('\n')) 按照行分隔,返回一个包含各行作为元素的列表,如果 num 指定则仅切片 num 个行. # string.translate(str, del="") 根据 str 给出的表(包含 256 个字符)转换 string 的字符,要过滤掉的字符放到 del 参数中
5.同行显示
print ("Hello World!",end = "") print ("Hello World!",end = "") # end 控制段落最后 # windows默认为 \r\n,Linux默认为 \n,mac默认为 \r
6.字符串拼接
name = 'Hans' age = '27' # 逗号拼接 print ('my name is',name,'and I am',age,'years old') # 加号拼接 print ('my name is'+name+'and I am'+age+'years old') # 占位符拼接(推荐使用) print ('my name is %s and I am %s years old'%(name,age))
List(列表)
列表的常用操作:增、删、改、查
1.创建列表
name = ['Hans','Jack','Tony','Peter'] name1 = list(['Hans','Jack','Tony','Peter'])
2.增加
name = ['Hans','Jack','Tony','Peter'] name.append('Joe') #在列表末尾添加元素 ['Hans', 'Jack', 'Tony', 'Peter', 'Joe'] name.insert(0, 'Ben') #在列表中插入元素 ['Ben', 'Hans', 'Jack', 'Tony', 'Peter']
append()方法可以动态地创建列表,例如,创建一个空列表,在使用该方法添加元素
3.删除
name = ['Hans','Jack','Tony','Peter'] name.remove('Hans') #不知道索引,知道元素值时使用 ['Jack', 'Tony', 'Peter'] n = name.pop(1) #如果不加索引值,删除列表最后一个元素 ['Hans', 'Tony', 'Peter'] print(n) #删除的元素可以储存在变量以便继续使用 Jack del name[2] #通过元素在列表中的位置删除 ['Hans', 'Jack', 'Peter'] name.clear() #清空列表 []
remove()方法只删除第一个指定的元素,如果要删除的元素在列表中重复,则需要使用循环
4.修改
name = ['Hans','Jack','Tony','Peter'] name[1] = 'Joe' #对指定元素进行修改 ['Hans','Joe','Tony','Peter'] name[1:3] = ['Joe', 'Ben'] #同时修改两个元素 ['Hans', 'Joe', 'Ben', 'Peter']
5.查询
name = ['Hans','Jack','Tony','Peter'] name[1] #取第二个元素 Jack name[1:] #取到最后一个元素 ['Jack','Tony','Peter'] name[1:-1] #取到倒数第二个元素 ['Jack','Tony'] name[0:-1:2] #最后的2为步长,从左到右隔一个去取 ['Hans','Tony'] name[3::-2] #第4个元素开始从右到左隔一个去取 ['Peter', 'Jack']
6.其他操作
6.1 sort() 对列表进行永久性排序
letter = ['c','a','d','b'] letter.sort() #对列表进行永久性排序 ['a', 'b', 'c', 'd'] letter.sort(reverse=True) #反向排序 ['d', 'c', 'b', 'a']
6.2 sorted() 对列表进行临时性排序
letter = ['c','a','d','b'] print(sorted(letter)) #对列表进行临时性排序 ['a', 'b', 'c', 'd'] print(sorted(letter,reverse=True)) #临时性反向排序 ['d', 'c', 'b', 'a'] print(letter) #['c', 'a', 'd', 'b']
6.3 reverse() 反转列表元素的排列顺序
letter = ['c','a','d','b'] letter.reverse() #['b', 'd', 'a', 'c']
6.4 更多方法
count #统计某个元素在列表中出现的次数: extend #可以在列表的末尾一次性追加另一个序列中的多个值 index #方法用于从列表中找出某个值第一个匹配项的索引位置
Tuple(元组)
元组被称为只读列表,即数据可以被查询,但不能被修改,所以,列表的切片操作同样适用于元组,元组写在小括号()里,元素之间用逗号隔开,虽然tuple的元素不可改变,但它可以包含可变的对象,比如list列表。
构造包含 0 个或 1 个元素的元组比较特殊,所以有一些额外的语法规则:
tup1 = () # 空元组 tup2 = (20,) # 一个元素,需要在元素后添加逗号
作用:
1.对于一些数据我们不想被修改,可以使用元组;
2.另外,元组的意义还在于,元组可以在映射(和集合的成员)中当作键使用——而列表则不行;元组作为很多内建函数和方法的返回值存在。
Dictionary(字典)
描述
字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据。
特点:
1.无序
2.键唯一
1.创建字典
dic = {'name':'alex'} dic1 = dict((('name','alex'),))
2.增加
# 方法一 dic1 = {'name':'alex'} dic1['age'] = 18 #通过赋值方式增加 print(dic1) # 方法二 dic1.setdefault('age',34) #键存在,不改动 print(dic1) #键存在,不改动,返回字典中相应的键对应的值 ret = dic1.setdefault('age',34) print(ret) #返回值为18 #键不存在,在字典中增加新的键值对,并返回相对应的值 ret1 = dic1.setdefault('hobby','girl') print(ret1) # 返回值为'girl'
3.删除
dic5 = {'name': 'alex', 'age': 18} #方法一: del dic5['name'] #del方法:删除键值对 print(dic5) #方法二: dic5.clear() #.clear方法:将字典内容清空 print(dic5) #方法三: res = dic5.pop('age') #pop方法:根据Key删除键值对 print(dic5) print(res) #返回值:返回删除的键值对 #方法四: a = dic5.popitem() #随机删除某组键值对,并以元组方式返回 print(a,dic5)
4.修改
dic3 = {'name':'alex','age':18,'hobby':'girl'} dic3['age'] = 55 print(dic3) #将dic4字典中的键值对更新到dic3中,如果键值重复,则覆盖 dic3 = {'name': 'alex', 'age': 18} dic4 = {'sex': 'male', 'hobby': 'girl', 'age': 36} dic3.update(dic4) print(dic3)
5.查询
dic3 = {'name':'alex','age':18,'hobby':'girl'} dic3['name'] #通过键查找值 list(dic3.keys()) #查找字典中所有的键 list(dic3.values()) #查找字典中所有的值 list(dic3.items()) #查找字典中所有的键值对
6.其他操作
6.1 dict.fromkeys
d1=dict.fromkeys(['host1','host2','host3'],'Mac') print(d1) d1['host1']='xiaomi' print(d1) ####### d2=dict.fromkeys(['host1','host2','host3'],['Mac','huawei']) print(d2) d2['host1'][0]='xiaomi' print(d2)
6.2 d.copy() 对字典 d 进行浅复制,返回一个和d有相同键值对的新字典
6.3 字典的嵌套
6.4 sorted(dict) : 返回一个有序的包含字典所有key的列表
dic={5:'555',2:'222',4:'444'} print(sorted(dic)) #对键排序并返回 print(sorted(dic.values())) #对值排序并返回 print(sorted(dic.items())) #对键值对排序并返回
6.5 字典的遍历
dic5={'name': 'alex', 'age': 18} for i in dic5: print(i,dic5[i]) for items in dic5.items(): print(items) for keys,values in dic5.items(): print(keys,values)
Set(集合)
集合是一个无序的,不重复的数据组合,它的主要作用如下:
- 去重,把一个列表变成集合,就自动去重了
- 关系测试,测试两组数据之前的交集、差集、并集等关系
s = set([3,5,9,10]) #创建一个数值集合 t = set("Hello") #创建一个唯一字符的集合 a = t | s # t 和 s的并集 b = t & s # t 和 s的交集 c = t – s # 求差集(项在t中,但不在s中) d = t ^ s # 对称差集(项在t或s中,但不会同时出现在二者中) 基本操作: t.add('x') # 添加一项 s.update([10,37,42]) # 在s中添加多项 使用remove()可以删除一项: t.remove('H') len(s) set 的长度 x in s 测试 x 是否是 s 的成员 x not in s 测试 x 是否不是 s 的成员 s.issubset(t) s <= t 测试是否 s 中的每一个元素都在 t 中 s.issuperset(t) s >= t 测试是否 t 中的每一个元素都在 s 中 s.union(t) s | t 返回一个新的 set 包含 s 和 t 中的每一个元素 s.intersection(t) s & t 返回一个新的 set 包含 s 和 t 中的公共元素 s.difference(t) s - t 返回一个新的 set 包含 s 中有但是 t 中没有的元素 s.symmetric_difference(t) s ^ t 返回一个新的 set 包含 s 和 t 中不重复的元素 s.copy() 返回 set “s”的一个浅复制