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 的长度
xins
测试 x 是否是 s 的成员
xnot ins
测试 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”的一个浅复制
更多方法