python入门(中)

  • 一、简介
  • 二、列表
    • 1.列表的定义
    • 2.列表的创建
    • 3.向列表中添加元素
    • 4.删除列表中的元素
    • 5.获取列表中的元素
    • 6.列表的常用操作符
    • 7.列表的其它方法
  • 三、元组
    • 1.创建和访问一个元组
    • 2.更新和删除一个元组
    • 3.元组相关的操作符
    • 4.内置方法
    • 5.解压元组
  • 四、字符串
    • 1.字符串的定义
    • 2.字符串的切片和拼接
    • 3.字符串的常用内置方法
    • 4.字符串格式化
  • 五、字典
    • 1.可变类型与不可变类型
    • 2.字典的定义
    • 3.创建和访问字典
    • 4.字典的内置方法
  • 六、集合
    • 1.集合的创建
    • 2.访问集合中的值
    • 3.集合的内置方法
    • 4.集合的转换
    • 5.不可变集合
  • 七、序列
    • 1.针对序列的内置函数

一、简介

python是一种通用编程语言,其在科学计算和机器学习领域具有广泛的应用。如果我们打算利用python来执行机器学习,那么对python有一些基本的了解就是至关重要的。本python入门系列体验就是为这样的初学者精心准备的。

二、列表

简单数据类型

  • 整型<class ‘int’>

  • 浮点型<class ‘float’>

  • 布尔型<class ‘bool’>
    容器数据类型

  • 列表<class ‘list’>

  • 元组<class ‘tuple’>

  • 字典<class ‘dict’>

  • 集合<class ‘set’>

  • 字符串<class ‘str’>

1.列表的定义

列表是有序的集合,没有固定大小,能够保存任意数量任意类型的python对象,语法为[元素1,元素2,…,元素n]。

  • 关键点是中括号“[]” 和 逗号“,”
  • 中括号 把所有元素绑在一起
  • 逗号 将每个元素一一分开

2.列表的创建

  • 创建一个普通列表
    【例子】
x = ['manday','tuesday','wednesday','thursday','friday']
print(x,type(x))
#['manday','tuesday','wednesday','thursday','friday'] <class 'list'>
x = [2,3,4,5,6,7]
print(x,type(x))
#[2,3,4,5,6,7] <class 'list'>
  • 利用range创建列表
x = list(range(1,11,2))
print(x,type(x))
#[1,3,5,7,9] <class 'list'>x = list(range(10,1,-2))
print(x,type(x))
#[10,8,6,4,2] <class 'list'>
  • 利用推导式创建列表
    【例子】
x = [0] * 5
print(x)
#[0,0,0,0,0]x = [0 for i in range(5)]
print(x)
#[0,0,0,0,0]x = [i for i in range(5)]
print(x)
#[1,2,3,4,5]x = [i ** 2 for i in range(1,10)]
print(x)
#[1,4,9,16,25,36,49,64,81]x = [i for i in range(10) if (i % 2) != 0 and (i % 3) ==0]
print(x)
#[3,9,15,21,27,33,39,45,51,57,63,69,75,81,87,93,99]

注意:
由于list的元素可以是任何对象,因此列表中所保存的是对象的指针。即使保存一个简单的[1,2,3],也有3个指针和3个整数对象。

x = [a] * 4操作中,只能创建4个指向list的引用,所有一旦a改变,x中4个a也会随之改变。
【例子】

x = [[0] * 3] * 4
print(x)
#[[0,0,0],[0,0,0],[0,0,0],[0,0,0]]x[0][0] =1
print(x)
#[[1,0,0],[1,0,0],[1,0,0],[1,0,0]]a = [0] * 3
x = [a] * 4
print(x)
#[[0,0,0],[0,0,0],[0,0,0],[0,0,0]]x[0][0] = 1
print(x)
#[[1,0,0],[1,0,0],[1,0,0],[1,0,0]]
  • 创建一个混合列表
    【例子】
mix = [1,'lsgo',3.14,[1,2,3]]
print(mix)
#[1,'lsgo',3.14,[1,2,3]]
  • 创建一个空列表
    【例子】
empty = []
print(empty)
#[]

列表不像元组,列表内容可更改(mutable),因此附加(append,extend)、插入(insert)、删除(remove,pop)这些操作都可以用在它身上。

3.向列表中添加元素

  • list.append(obj)在列表末尾添加新的对象,只接受一个参数,参数可以是任何数据类型,被追加的元素在list中保持着原结构类型。
  • 此元素如果是一个list,那么这个list将作为一个整体进行追加,注意append()和extend()的区别。
    【例子】
x = ['M','T','W']
x.append(['q','r'])
print(x)
#['M','T','W',['q','r']]print(len(x))
#4
  • list.extend(seq)在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)
    【例子】
x = ['M','T','W']
x.extend(['q','r'])
print(x)
#['M','T','W','q','r']print(len(x))
#5

严格来说append是追加,把一个东西整体添加在列表后,而extend是扩展,把一个东西里的所有元素添加在列表后。

  • list.insert(index, obj)在编号index位置插入obj。
    【例子】
x = ['M','T','W']
x.insert(2,'r')
print(x)
#['M','T','r',W']print(len(x))
#4

4.删除列表中的元素

  • list.remove(obj)移除列表中某个值的第一个匹配项
x = ['M','T','W']
x.remove(’M‘)
print(x)
#['T','W']
  • list.pop([index=-1])移除列表中的一个元素(默认最后一个元素),并且返回该元素的值。
    【例子】
x = ['M','T','W']
y = x.pop()
print(y)#'W'y = x.pop(0)
print(y)#'M'

remove 和pop都可以删除元素,前者是指定具体要删除的元素,后者是指定一个索引。

  • del var1[, var2 …]删除单个或多个对象。
    【例子】
    如果知道要删除的元素在列表中的位置,可使用del语句。
x = ['M','T','W']
del x[0:2]
print(x)  #['W']

如果你要从列表中删除一个元素,且不再以任何方式使用它,就使用 del 语句;如果你要在删除元素后还能继续使用它,就使用方法pop()。

5.获取列表中的元素

  • 通过元素的索引值,从列表获取单个元素,注意,列表索引值是从0开始的。
  • 通过将索引指定为-1,可让python返回最后一个列表元素,索引-2返回倒数第二个列表元素,以此类推。

切片的通用写法是 start : stop : step

  • 情况1 - “start :”
  • 以step 为1(默认)从编号start往列表尾部切片。
  • 情况2 - “: stop”
  • 以step 为1(默认)从列表头部往编号stop切片。
  • 情况3 - “start : stop”
  • 以step 为1(默认)从编号start往编号stop切片。
  • 情况4 - “start : stop : step”
  • 以具体的step 为1(默认)从编号start往编号stop切片。注意最后把step设为-1,相当于将列表反向排列。
  • 情况5 - " : "
  • 复制列表中的所有元素(浅拷贝)。
    【例子】深拷贝与浅拷贝
list1 = [123,456,789,213]
list2 = list1
list3 = list1[:]print(list2) #[123,456,789,213]
print(list3) #[123,456,789,213]
list1.sort()
print(list2) #[123,213,456,789]
print(list3) #[123,456,789,213]list1 = [[123,456],[789,213]]
list2 = list1
list3 list1[:]
print(list2) #[[123,456],[789,213]]
print(list3) #[[123,456],[789,213]]
list[0][0] = 111
print(list2) #[[111,456],[789,213]]
print(list3) #[[123,456],[789,213]]

6.列表的常用操作符

  • 等号操作符:==
  • 连接操作符:+
  • 重复操作符: *
  • 成员关系操作符:in、not in

[等号==],只有成员、成员位置都相同时才返回True。

列表拼接有两种方式,用加号+ 和乘号*,前者首位拼接,后者复制拼接。
前面三种方法(append,extend,insert)可对列表增加元素,它们没有返回值,是直接修改了原数据对象。而将两个list相加,需要创建新的list对象,从而需要消耗额外的内存,特别是当list较大时,尽量不要使用“+”来添加list。

7.列表的其它方法

list.count(obj)统计某个元素在列表中出现的次数。
list.reverse()反向列表中的元素。
list.sort(key=None, reverse=False)对原列表进行排序。

  • key --主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自可迭代对象中,指定可迭代对象中的一个元素来进行排序。
  • reverse --排序规则,True降序 ,False升序(默认)。
  • 该方法没有返回值,但是会对列表的对象进行排序。

三、元组

元组 定义语法为:(元素1,元素2,… , 元素n)

  • 小括号把所有元素绑在一起
  • 逗号将每个元素一一分开

1.创建和访问一个元组

  • python的元组与列表类似,不同之处在于tuple被创建后就不能对其进行修改,类似字符串。
  • 元组使用小括号,列表使用方括号。
  • 元组与列表类似,也用整数来对它进行索引(indexing)和切片(slicing)。
  • 创建元组可以用小括号(),也可以什么都不用,为了可读性,建议还是用()。
  • 元组中只包含一个元素时,需要在元素后面添加逗号,否则括号会被当做运算符使用。
    【例子】
x = (1)
print(type(x)) #<class 'int'>
x = 2,3,4,5
print(type(x)) #<class 'tuple'>
x = []
print(type(x)) #<class 'list'>
x = ()
print(type(x)) #<class 'tuple'>
x = (1,)
print(type(x)) #<class 'tuple'>

【例子】

print(8 * (8)) #64
print(8 * (8,) #(8,8,8,8,8,8,8,8)

【例子】创建二维元组

x = (1,10.31,'python'),('data',11)
print(x)
#((1,10.31,'python'),('data',11))print(x[0])
# (1,10.31,'python')
print(x[0][0],x[0][1],x[0][2])
# 1 10.31 pythonprint(x[0][0:2])
# (1,10.31)

2.更新和删除一个元组

【例子】

week = ('monday','tuesday','thursday','friday')
week = week[:2] + ('wednesday',) + week[2:]
print(week) #('monday','tuesday','wednesday','thursday','friday')

【例子】元组有不可更改(immutable)的性质,因此不能直接给元组的元素赋值,但是只要元组中的元素可更改(mutable),那么我们直接更改其元素,注意这跟赋值其元素不同。

t1 = (1,2,3,[4,5,6])
print(t1) #(1,2,3,[4,5,6])t1[3][0] = 9
print(t1) #(1,2,3,[9,5,6])

3.元组相关的操作符

  • 等号操作符:==
  • 连接操作符:+
  • 重复操作符:*
  • 成员关系操作符: in、not in

等号==,只有成员、成员位置都相同时才返回True。

元组拼接有两种方式,用加号+ 和乘号*,前者用首位拼接,后者复制拼接。

4.内置方法

元组大小和内容都不可改变,因此只有count和index两种方法。

5.解压元组

【例子】解压(unpack)一维元组(有几个元素左边括号定义几个变量)

t = (1,10.31,'python')
(a,b,c) = t
print(a,b,c)
#1 10.31 python

【例子】解压二维元组(按照元组里的元组结构来定义变量)

t = (1,10.31,('ok','python'))
(a,b,(c,d)) = t
print(a,b,c,d)
# 1 10.31 ok python

【例子】如果你只想要元组其中几个元素,用通配符*,英文名叫wildcard,在计算机语言中代表一个或多个元素。下例就是把多个元素丢给了rest变量。

t = 1,2,3,4,5
a,b,*rest,c = t
print(a,b,c) #1 2 5
print(rest) #[3,4]

【例子】如果你根本不在乎rest变量,那么就用通配符*加上下划线_。

t = 1,2,3,4,5
a,b,*_ = t
print(a,b) # 1 2

四、字符串

1.字符串的定义

  • python中字符串被定义为引号之间的字符集合。
  • python支持使用成对的单引号或双引号。
  • python的常用转义字符
转义字符 描述
\\ 反斜杠符号
\’ 单引号
\" 双引号
\n 换行
\t 横向制表符(TAB)
\r 回车

【例子】如果字符串中需要出现单引号或双引号,可以使用转义符号\对字符串中的符号进行转义。

print('let\'s go') # let's go
print("let's go") # let's go
print('c:\\now') # c:\now

【例子】原始字符串只需要在字符串前边加一个英文字母r即可。

print(r'c:\program\intel\wifi\help')
# c:\program\intel\wifi\help

【例子】三引号允许一个字符串多跨行,字符串中可以包含换行符、制表符以及其他特殊字符。

2.字符串的切片和拼接

  • 类似于元组具有不可修改性
  • 从0开始(和Java一样)
  • 切片通常写成start:end这种形式
  • 索引值可正可负,正索引从0开始,从左往右;负索引从-1开始,从右往左。使用负数索引时,会从最后一个元素开始计数。最后一个元素的位置编号是-1。

3.字符串的常用内置方法

  • capitalize()将字符串的第一个字符转换为大写。
  • lower()转换字符串中所有大写字符为小写。
  • upper()转换字符串中所有小写字母为大写。
  • swapcase()将字符串中大写转换为小写,小写转换为大写。
    【例子】
str1 = 'xiaoxie'
print(str1.capitalize()) #Xiaoxie
str2 = 'DAXIExiaoxie'
print(str2.lower()) #daxiexiaoxie
print(str2.upper()) #DAXIEXIAOXIE
print(str2.swapcase()) #daxieXIAOXIE
  • count(str, beg = 0, end = len(string))返回str在string里面出现的次数,如果beg或者end指定则返回指定范围内str出现的次数。
    【例子】
str2 = 'DAXIExiaoxie'
print(str2.count(’xi‘)) #2
  • endswith(suffix, beg=0, end=len(string))检查字符串是否以指定子字符串suffix结束,如果是,返回True,否则返回False。如果beg和end指定值,则在指定范围内检查。
  • startswith(substr, beg=0, end=len(string))检查字符串是否以指定子字符串substr开头,如果是,返回True,否则返回False。如果beg和end指定值,则在指定范围内检查。
    【例子】
str2 = 'DAXIExiaoxie'
print(str2.endswith(’ie‘)) #True
print(str2.endswith(’xi‘)) #False
print(str2.startswith(’Da‘)) #False
print(str2.startswith(’DA‘)) #True
  • find(str, beg=0, end=len(string))检测str是否包含在字符串中,如果指定范围beg和end,则检查是否包含在指定范围内,如果包含,返回开始的索引值,否则返回-1。
  • rfind(str, beg=0, end=len(string))类似于find()函数,不过是从右边开始查找。
    【例子】
str2 = 'DAXIExiaoxie'
print(str2.find(’xi‘)) #5
print(str2.find(’ix‘)) #-1
print(str2.rfind(’xi‘)) #9
  • isnumeric()如果字符串中只包含数字字符,则返回True,否则返回False。
  • ljust(width[, fillchar])返回一个原字符串左对齐,并使用fillchar(默认空格)填充至长度width的新字符串。
  • rjust(width[, fillchar])返回一个原字符串右对齐,并使用fillchar(默认空格)填充至长度width的新字符串。
    【例子】
str4 = '1101'
print(str4.ljust(8,'0')) #11010000
print(str4.rjust(8,'0')) #00001101
  • lstrip([chars])截掉字符串左边的空格或指定字符。
  • rstrip([chars])删除字符串末尾的空格或指定字符。
  • strip([chars])在字符串上执行 lstrip()和 rstrip()
  • partition(sub)找到子字符串sub,把字符串分为一个三元组(pre_sub,sub,fol_sub),如果字符串中不包含sub则返回(‘原字符串’,",")。
  • rpartition(sub)类似于partition()方法,不过是从右边开始查找。
  • replace(old,new[,max])把将字符串中的old替换成new,如果max指定,则替换不超过max次。
  • split(str="",num)不带参数默认是以空格为分隔符切片字符串,如果num参数有设置,则仅分割num个子字符串,返回切片后的子字符串拼接的列表。
  • splitlines([keepends])按照行(’\r’,’\r\n’,’\n’)分割,返回一个包含各行作为元素的列表,如果参数keepends为False,不包含换行符,如果为True,则保留换行符。
  • maketrans(intab, outtab)创建字符映射的转换表,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。
  • translate(table,deletechars="")根据参数table给出的表,转换字符串的字符,要过滤掉的字符放到deletechars参数中。

4.字符串格式化

  • format格式化函数
    【例子】
str8 = "{0} love {1}".format('i','lsg') #位置参数
print(str8) # i love lsgstr8 = "{a} love {b}".format(a='i',b='lsg') #关键字参数
print(str8) # i love lsgstr8 = "{0} love {b}".format('i',b='lsg') #位置参数要在关键字参数之前
print(str8) # i love lsgstr8 = '{0:.2f}{1}'.format(27.658,'GB') #保留小数点后两位
print(str8) #27.66GB
  • python字符串格式化符号
符号 描述
%c 格式化字符及ASCII码
%s 格式化字符,用str() 方法处理对象
%r 格式化字符,用rper() 方法处理对象
%d 格式化整数
%o 格式化无符号八进制数
%x 格式化无符号十六进制数
%X 格式化无符号十六进制数(大写)
%f 格式化浮点数字,可指定小数点后的精度
%e 用科学计数法格式化浮点数
%E 作用同%e,用科学计数法格式化浮点数
%g 根据值的大小决定使用%f或%e
%G 作用同%g, 根据值的大小决定使用%f或%E
  • 格式化操作符辅助命令
符号 功能
m.n m是显示的最小总宽度,n是小数点后的位数(如果可用的话)
- 用作左对齐
+ 在整数前面显示加号(+)
# 在八进制数前面显示零(‘0’),在十六进制前面显示‘0x’或者‘0X’(取决于用的是‘x’还是‘X’)
0 显示的数字前面填充‘0’而不是默认的空格

五、字典

1.可变类型与不可变类型

  • 序列是以连续的整数为索引,于此不同的是,字典以“关键字”为索引,关键字可以是任意不可变类型,通常用字符串或数值。

  • 字典是python唯一的一个映射类型,字符串、元组、列表属于序列类型。
    如何快速判断一个数据类型X是不是可变类型呢?两种方法:

  • 麻烦方法:用id(X)函数,对X进行某种操作,比较操作前后的id,如果不一样,则X不可变,如果一样,则X可变。

  • 便捷方法:用hash(X),只要不报错,证明X可被哈希,即不可变,反过来不可被哈希,即可变。
    【例子】

i = 1
print(id(i)) #140732167000896
i = i + 2
print(id(i)) #140732167000960l = [1,2]
print(id(i)) #4300825160
l.append('python')
print(id(l)) #4300825160
  • 整数i在加1之后的id和之前不一样,因此加完之后的这个i(虽然名字没变),但不是加之前的那个i了,因此整数是不可变类型。
  • 列表l在附加‘python’之后的id和之前的一样,因此列表是可变类型。
    【例子】
print(hash('name')) #7047218704141848153
print(hash((1,2,'python'))) #1704535747474881831
print(hash([1,2,'python'])) #TypeError:unhashable type:'list'print(hash({1,2,3})) #TypeError:unhashable type:'set'
  • 数值、字符和元组都能被哈希,因此它们是不可变类型。
  • 列表、集合、字典不能被哈希,因此它是可变类型。

2.字典的定义

字典是无序的键:值(key:value)对集合,键必须是互不相同的(在同一个字典之内)。

  • dict内部存放的顺序和key放入的顺序是没有关系的。
  • dict查找和插入发速度极快,不会随着key的增加而增加,但是需要占用大量的内存。

字典定义的语法为{元素1,元素2,…,元素n}

  • 其中每一个元素是一个键值对 --键:值(key:value)
  • 关键点是大括号{},逗号,和冒号:
  • 大括号–把所有元素绑在一起
  • 逗号–将每个键值对分开
  • 冒号–将键和值分开

3.创建和访问字典

如果取的键在字典中不存在,会直接报错KeyError。

4.字典的内置方法

  • dict.fromkeys(seq[,value])用于创建一个新字典,以序列seq中元素做字典的键,value为字典所有键对应的初始值。
  • dict.keys()返回一个可迭代对象,可以使用list()来转换为列表,列表为字典中的所有键。
  • dict.values()返回一个迭代器,可以使用list()来转换为列表,列表为字典中的所有值。
  • dict.items()以列表返回可遍历的(键,值)元组数组。
  • dict.get(key,default=None)返回指定键的值,如果值不在字典中返回默认值。
  • dict.setdefault(key,default=None)和get()方法类似,如果键不存在于字典中,将会添加键并将值设为默认值。
  • key in dict in操作符用于判断键是否存在于字典中,如果键在字典dict返回true,否则返回false。而not in操作符正好相反。
  • dict.pop(key[,default])删除字典给定键key所对应的值,返回值为被删除的值。key值必须给出。若key不存在,则返回default值。
  • del dict[key]删除字典给定键key所对应的值。
  • dict.popitem()随机返回并删除字典中的一对键和值,如果字典已经为空,却调用了此方法,就报出KeyError异常。
  • dict.clear()用于删除字典内所有元素。
  • dict.copy()返回一个字典的浅复制。
    【例子】直接赋值和copy的区别
dict1 = {'user':'lsg','num':[1,2,3]}
#引用对象
dict2 = dict1
#浅拷贝父对象(一级目录),子对象(二级目录)不拷贝,还是引用
dict3 = dict1.copy()print(id(dict1)) #148635574728
print(id(dict2)) #148635574728
print(id(dict3)) #148635574344#
dict1['user'] = 'root'
dict1['num'].remove(1)#
print(dict1) #{'user':'root','num':[2,3]}
print(dict2) #{'user':'root','num':[2,3]}
print(dict3) #{'user':'lsg','num':[2,3]}
  • dict.updata(dict2)把字典参数dict2的key:value对更新到字典dict里。
    【例子】
dic = {'name':'lsg','age':7}
dic2 = {'sex':'female','age':8}
dic.updata(dic2)
print(dic)
#{'name':'lsg','age':8,'sex':'female'}

六、集合

python中set与dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key.
注意,key为不可变类型,即可哈希的值。

1.集合的创建

  • 先创建对象再加入元素。
  • 在创建空集合的时候只能用s = set(),因为s = {}创建的是空字典。
  • 使用set(value)工厂函数,把列表或元组转换为集合。
    【例子】去掉列表中重复的元素
lst = [0,1,2,3,4,5,5,3,1]
temp = []
for item in lst:if item not in temp:temp.append(item)
print(temp) #[0,1,2,3,4,5]a = set(lst)
print(list(a)) #[0,1,2,3,4,5]

从结果发现集合的两个特点:无序(unordered)和唯一(unique)。

由于set存储的是无序集合,所以我们不可以为集合创建索引或执行切片(slice)操作,也没有键(keys)可用来获取集合中元素的值,但是可以判断一个元素是否在集合中。

2.访问集合中的值

  • 可以使用len()内建函数得到集合的大小。
  • 可以使用for把集合中的数据一个个读取出来。
  • 可以通过in 或not in判断一个元素是否在集合中已存在

3.集合的内置方法

  • set.add(element)用于集合添加元素,如果添加的元素在集合中已存在,则不执行任何操作。
  • set.updata(set)用于修改当前集合,可以添加新的元素或集合到当前集合中,如果添加的元素在集合中已存在,则该元素只会出现一次,重复的会忽略。
  • set.remove(item)用于移除集合中的指定元素。如果元素不存在,则会发生错误。
  • set.discard(item)用于移除集合中的指定元素。如果元素不存在,不会发生错误。
  • set.pop()用于随机移除一个元素。
    由于set是无序和无重复元素的集合,所以两个或多个set可以做数学意义上的集合操作。
  • set.intersection(set1,set2)返回两个集合的交集。
  • set1 & set2返回两个集合的交集。
  • set.intersection_update(set1,set2)交集,在原始的集合上移除不重叠的元素。
  • set.union(set1,set2)返回两个集合的并集。
  • set1 | set2 返回两个集合的并集。
  • set.difference(set)返回集合的差集。
  • set1 - set2返回集合的差集。
  • set.difference(set)集合的差集,直接在原来的集合中移除元素,没有返回值。
  • set.symmetric_difference(set)返回集合的异或。
  • set1 ^ set2返回集合的异或。
  • set.symmetric_difference_update(set)移除当前集合中在另外一个指定集合相同的元素,并将另一个指定集合中不同的元素插入到当前集合中。
  • set.issubset(set)判断集合是不是被其他集合包含,如果是返回True,否则返回False。
  • set1 <= set2判断集合是不是被其他集合包含,如果是返回True,否则返回False。
  • set.issuperset(set)判断集合是不是包含其他集合,如果是返回True,否则返回False。
  • set1 >= set2判断集合是不是包含其他集合,如果是返回True,否则返回False。
  • set.isdisjoint(set)用于判断两个集合是不是不相交,如果是返回True,否则返回False。

4.集合的转换

【例子】

se = set(range(4))
li = list(se)
tu = tuple(se)
print(se) #{0,1,2,3}
print(li) #[0,1,2,3]
print(tu) #(0,1,2,3)

5.不可变集合

python提供了不能改变元素的集合的实现版本,即不能增加或删除元素,类型名叫frozenset。需要注意的是frozenset仍然可以进行集合操作,只是不能用带有update的方法。

  • frozenset([iterable])返回一个冻结的集合,冻结后集合不能再添加或删除任何元素。

七、序列

在python中,序列类型包括字符串、列表、元组、集合和字典,这些序列支持一些通用的操作,但比较特殊的是,集合和字典不支持索引、切片、相加和相乘的操作。

1.针对序列的内置函数

  • list(sub)把一个可迭代对象转换为列表。

  • tuple(sub)把一个可迭代对象转换为元组。

  • str(obj)把obj对象转换为字符串

  • len(s)返回对象(字符、列表、元组等)长度或元素个数。

  • max(sub)返回序列或者参数集合中的最大值。

  • min(sub)返回序列或者参数集合中的最小值。

  • sum(iterable[,start=0])返回序列iterable与可选参数start的总和。

  • sorted(iterable,key=None,reverse=False)对所有可迭代的对象进行排序操作。
    其中:
    iterable --可迭代的对象
    key --主要用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素类进行排序。
    reverse --排序规则,True降序,False升序(默认)。
    返回重新排序的列表。

  • reversed(seq)函数返回一个反转的迭代器。
    其中 seq – 要转换的序列,可以是tuple,string,list或range。

  • enumerate(sequence,[start = 0]) 用于将一个可遍历的数据对象(如列表、元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在for循环当中。

  • zip(iter1 [,iter2 […]])
    用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的对象,这样做的好处是节约了不少的内存。
    可以使用list()转换来输出列表。
    如果各个迭代器的元素个数不一致,则返回列表长度与最短对象的对象相同,利用*号操作符,可以将元组解压为列表。
    【例子】

a = [1,2,3]
b = [4,5,6]
c = [4,5,6,7,8]
zipped = zip(a,b)
print(list(zipped))#[(1,4),(2,5),(3,6)]
zipped = zip(a,c)
print(list(zipped))#[(1,4),(2,5),(3,6)]a1,a2 = zip(*zip(a,b))
print(list(a1))#[1,2,3]
print(list(a2))#[4,5,6]

python入门(中)相关推荐

  1. Python基础入门:Task2(day06)Python入门(中)--阿里云天池

    Task02 Day06 集合 Python 中set与dict类似,也是一组key的集合,但不存储value.由于key不能重复,所以,在set中,没有重复的key num = {} print(t ...

  2. python入门第一课_入门第一课 Python入门涉及的问题及简单示例

    很多初学者都在问:我想自学Python,该怎样入门?入门选择哪些书籍? 下面,我以自己的理解作出解答. 1.先说明大体的学习进度. Python确实入门较为容易,语法清晰易懂.一旦入了门再想提高就和其 ...

  3. python游戏中调整箭头下落速度_入门 | 三行Python代码,让数据预处理速度提高2到6倍...

    原标题:入门 | 三行Python代码,让数据预处理速度提高2到6倍 选自TowardsDataScience 作者:George Seif,机器之心编译 在 Python 中,我们可以找到原生的并行 ...

  4. python入门指南_Python中的逻辑门–入门指南

    python入门指南 This article comprehensively covers the different logic gates in Python. Logic gates are ...

  5. 如果只能从市面上的Python入门书中选择一本送给你,那我一定会选这本……

    大家好,欢迎来到Crossin的编程教室!我是Crossin. 今天我要给你们送本书. 这本书,亚马逊评分4.5,豆瓣评分8.5,曾获得2011年JOLT(有"软件业界的奥斯卡"之 ...

  6. python类中的属性分为类属性和实例属性两种_python从入门到大神---1、初始化实例、类属性、方法...

    python从入门到大神---1.初始化实例.类属性.方法 一.总结 一句话总结: 方法不加括号是代码段:感觉python方法和js,php很类似,不加括号是代码段,加括号变成方法,比如f,f() 1 ...

  7. ArcGIS Pro 中的 Python 入门

    ,欢迎也在微信公众号查看. Python脚本使ArcGIS Pro中的工作流自动化成为可能.ArcGIS pro中采用的是Python3.在本例中,将首先介绍Python 语法的一些基础知识,然后编写 ...

  8. python中r55的执行结果是_Abaqus+python入门体会(simwe-flin55)

    Abaqus/python 入门体会 ( 初稿) 长安大学   姜峰林 flin55@126.com  2009.2.1 #====================================== ...

  9. VS Code中的Python入门

    VS代码中的Python入门 在本教程中,您将使用Python 3在Visual Studio Code中创建最简单的Python"Hello World"应用程序. 通过使用Py ...

最新文章

  1. 理论优美的深度信念网络,Hinton老爷子北大最新演讲
  2. pandas打乱行次序
  3. [转]如何提升你的沟通技巧
  4. WebAPI性能优化之压缩解压
  5. 浏览器停止加载页面内容
  6. 中国第一大善人是他!福布斯2019中国慈善榜发布:马云才排第三
  7. C#Repeater控件的使用
  8. 计算机设备硬件设备,计算机硬件设备有哪些
  9. Ubuntu下读取Xbox360手柄输出
  10. WebSphere漏洞总结复现
  11. tf.flags.DEFINE解释
  12. 趣图 | 念念不忘必有回响
  13. 移动端微信浏览器调试工具整理eruda,微信x5调试工具无法使用,推荐新工具eruda、vconsole和debugxweb
  14. 显示隐藏图片html,JavaScript实现显示和隐藏图片
  15. 人工智能——机器学习与深度学习思维导图
  16. JAVA数组自动排序
  17. HANA DB重置SYSTEM密码
  18. 连接雅虎财经API获取股票信息
  19. 运营商2019春招面试经验(广东移动市场岗+湖南联通技术岗)
  20. 基于SSM框架的超市管理系统

热门文章

  1. 【一周头条盘点】中国软件网(2018.10.29~2018.11.2)
  2. 好看的vscode深色主题,搜索主题名称即可设置
  3. 微服务化与DDD—分层架构、洋葱架构、六边形架构 架构设计
  4. Linux嵌入式设备内存问题定位
  5. Deep Learing 记录:电影评论分类——二分类问题
  6. PMP新考纲 敏捷题目 (四)
  7. 使用74LS164和74LS165实现简单I/O扩展
  8. mysql导致bin文件过大_mysql-bin日志文件过大导致磁盘空间不足问题解决方法
  9. 小孔成像总结_相机标定是怎么回事——相机成像数学模型
  10. (汇总篇)语义SLAM相关开源方案| 全球优秀作者与实验室 | SLAM学习资料整理