1.定义
1.数据结构:通过某种方式组织在一起的数据元素的集合。这些数据元素可以说数字或者字符,甚至可以是其他数据结构。在python中,最基本的数据结构是序列。
2.索引:序列中的每个元素被分配一个序号。注意索引默认从0开始。
在python中,内建了6中序列:列表、元组、字符串、unicode字符串、buffer对象、xrange对象。
2.通用序列操作
所有序列都可以进行某些特定的操作:索引、分片、加、乘、检查某个元素是否属于序列的成员(成员资格)、内建函数(长度、最小值、最大值)。在这里还有一个重大的操作未提及—–迭代,指依次对序列中的每个元素重复执行某些操作,后续会详细分析,这里就不做过多的说明。
2.1索引
序列中所有元素都是有编号的—-从0开始,可以通过编号进行访问。通过情况下,索引值为正数,但是python中也可以为负数,代表从右开始计数。若为负数时,开头第一位数为-1,而不是0,这样避免了与从左开始的第一个元素重合。
1 __author__ = 'zcy' 2 3 greeting='Hello' 4 5 print(greeting[0]); 6 7 print(greeting[-1]);
View Code

2.2分片
分片,个人理解通过指定左右两个数字来,获取其中间对应的值。分片通过冒号隔开两个索引来实现,相当于是索引的升级版。提取时,包含左边的索引,而不包含右边的索引。注意若从左开始,索引也是从0 开始,从右边时,从-1开始。
在分片中,只要最左边的索引比它右边的晚出目前序列中,结果就是一个空序列。如果分片所得的包含末尾的元素,那么只需置空最后一个索引。
1 numbers=[1,2,3,4,5,6,7,8,9,10] 2 print(numbers[3:6]) 3 print(numbers[0:1]) 4 print(numbers[-5:-1]) 5 print(numbers[-11:0]) 6 print(numbers[-3:]) 7 print(numbers[:3]) 8 print(numbers[:])
View Code

分片的开始和结束都需要指定,而在分片中存在另外一个参数—步长,一般是隐式设置的,默认为1.在分片中我们也可以设置步长,按照设置的步长来遍历序列中的元素。
1 numbers=[1,2,3,4,5,6,7,8,9,10] 2 print(numbers[0:10:1]) 3 print(numbers[0:10:2]) 4 print(numbers[::4]) 5 print(numbers[8:3:-1]) 6 print(numbers[10:0:-2]) 7 print(numbers[0:10:-2]) 8 print(numbers[::-2])
View Code
开始点的元素包括在结果之中,而结束点的元素则不在分片之内。
当使用一个负数作为步长时,必须让开始点大于结束点。对于一个正数步长,会从序列的头开始向右提取元素,而对于负步长,则是从序列尾部开始向左提取元素。
2.3序列相加
使用加运算符可以进行序列的连接操作
1 number=[1,2,3]+[4,5,6] 2 print(number) 3 4 number1='Hello, '+'world!' 5 print(number1) 6 7 number2=[1,2,3]+'world!' 8 print(number2)
View Code

正如上面截图,若为同意类型时,可以进行连接,否则无法连接,抛出异常。
2.4乘法
用序列乘以某个数字,会得到一个新的序列,而在新的序列中,原来序列将被重复乘以这个数。
1 print('python,'*5)
2
3 print([2]*10)
4
5 print([None]*10)
View Code

2.5成员资格
成员资格即检查当前元素是否在当前序列中。若存在,返回true,否则返回false。
str='python'
print('p' in str)
print('a' in str)
View Code

2.6长度、最小值和最大值
长度:len;最小:min;最大:max
1 numbers=[100,20,300] 2 print(len(numbers)) 3 print(max(numbers)) 4 print(min(numbers))
View Code
2.列表:Python的‘苦力’
列表使用于序列的标准操作,是可以修改的。下面通过代码来看一下列表所拥有的特性。
1 # 元素复制
2 number=[1,2,3,4,5,6]
3 print(number)
4 number[1]=5
5 print('元素复制:',number)
6
7 # 删除元素
8 del number[1]
9 print('删除元素:',number)
10
11 # 分片赋值
12 number=[1,5]
13 number[1:1]=[2,3,4]
14 print('分片赋值:',number)
15
16 # 追加对象 append
17 number.append(10)
18 print('append:',number)
19
20 # 元素在列表中出现的次数 count
21 print('count:',number.count(1))
22
23 # 将一个列表添加到另一个列表中 extend
24 a=[1,2]
25 b=[3,4]
26 a.extend(b)
27 print('extend:',a)
28
29 # 找出摸个元素的索引 index
30 name=['a','a','c','d','e','f']
31 print('index:',name.index('a'))
32 print('index:',name.index('g'))
33
34 # 将对象插入到列表中 insert
35 number=[1,2]
36 number.insert(1,'aa')
37 print('insert:',number)
38
39 # 移除列表中的一个元素,默认为最后一个
40 print('pop:',number.pop)
41
42 # 移除列表中某个值的第一个匹配项
43 x=['a','b','c']
44 print('remove:',x.remove('a'))
45
46 # 将列表中元素反向存放 reverse
47 x=[1,2,3]
48 x.reverse
49 print('reverse:',x)
50
51 # 列表中元素排序 sort
52 x.sort
53 print('sort:',x)
54
55
56 返回结果:
57 [1, 2, 3, 4, 5, 6]
58 元素复制: [1, 5, 3, 4, 5, 6]
59 删除元素: [1, 3, 4, 5, 6]
60 分片赋值: [1, 2, 3, 4, 5]
61 append: [1, 2, 3, 4, 5, 10]
62 count: 1
63 extend: [1, 2, 3, 4]
64 index: 0
65 File "H:/PythonProject/PythonBasics/bolg.py", line 8, in <module>
66 print('index:',name.index('g'))
67 ValueError: 'g' is not in list
68 insert: [1, 'aa', 2]
69 pop: 2
70 remove: None
71 reverse: [3, 2, 1]
72 sort: [1, 2, 3]
View Code
append方法,在列表末尾追加新的元素;而inset方法,在列表指定位置新增新的元素
extend与‘+’区别在于,extend方法返回一个修改的列表,而原始的连接操作,则是返回一个全新的列表
pop方法是唯一一个即能修改列表又能返回元素的列表方法
3.元组:不可变序列
元组也是属于序列的一种,但是元组恰恰和列表相反,元组是不可变的,即定义之后,不能再改变元素。创建元组使用小括号,也可以不用,为了美观和便于识别,还是一般会加小括号。在元组中,若不使用括号,即使只有一个元素,也需要加括号,否则视为普通的数字或字符。例如:1,2,3;(1,2,3);42,;(42,)
tuple,可以将一个序列作为参数转换为元组
1 print(1,2,3) 2 print((1,2,3)) 3 print(42,) 4 print((42,)) 5 6 7 number=[1,2,3] 8 print(number) 9 print(tuple(number))
View Code

4.字符串
字符串也是属于序列的一种,所有它也拥有序列的一些基本特性。字符串是不可变的,由于分片复制都是不合法的。
一般格式化字符串使用‘%s’。%s称为转换说明符,标记了需要插入转换值的位置。若需要在字符串中包括百分号,则必须使用%%。
1 format='Hello,%s.%s enough for ya?'
2 values=('world','Hot')
3 print(format % values)
4
5
6 结果:
7 Hello,world.Hot enough for ya?
View Code
1.%字符:标记转换说明符的开始
2.转换标志(可选):如s
3.最小字段宽度(可选):转换后的字符串至少应该具有指定的宽度,如果是*,则宽度会从值元组中读出
4.点(.)后跟精度值(可选):如果转换的是实数,精度值就表明出目前小数点后的位数。如果转换的是字符串,那么该数字就表明最大字段宽度。
5.转换类型:
字符串格式化转换类型
| 转换类型 | 含义 |
| d、i | 带符号的十进制正数 |
| o | 不带符号的八进制 |
| u | 不带符号的十进制 |
| x | 不带符号的十六进制(小写) |
| X | 不带符号的十六进制(大写) |
| e | 科学计算法表明的浮点数(小写) |
| E | 科学计算法表明的浮点数(大写) |
| f、F | 十进制浮点数 |
| g | 如果指数大于-4或者小于精度值则和e一样,其他情况与f形同 |
| G | 如果指数大于-4或者小于精度值则和E一样,其他情况与F形同 |
| C | 单字符(接受正数或者单字符字符串) |
| r | 字符串(使用repr转换人员python对象) |
| s | 字符串(使用str转换人员python对象) |
1 from math import pi
2
3 print('Price of eggs: $%d' % 42)
4 print('Jexadecimal price of eggs:%x'% 42)
5 print('%10f' % pi)
6 print('%10.2f' % pi)
7 print('%.5s' % 'Fuido van Rossum')
8 print('%010.2f' % pi)
9
10 结果:
11 Price of eggs: $42
12 Jexadecimal price of eggs:2a
13 3.141593
14 3.14
15 Fuido
16 0000003.14
View Code
字符串有许多列表的方法,同时也有特有的方法:
1.find:在一个字符串中,查找某个字符串,然后其左边的索引,若不存在,返回-1
2.join:将列表的元素通过某个字符串连接
3.lower:返回字符串的小写字字母版
4.replace:返回某个字符串的所有匹配项均被替换之后得到的字符串
5.split:通过特殊的字符拆分当前字符串,若不提供,默认吧空格做份分隔符
6.strip:返回去除两侧空格的字符串
7.tanslate:替换字符串中的某些部分,优势在于可以同时进行多行替换。
5.写在最后
由于最近时间缘由,白天需要忙工作上的事情,偶尔下班回家还需要处理自己的事情,可能更新较为缓慢。写博客的时间,大多是下班之后,自己边查阅书籍和自己的印象来写的,主要是为了加深自己的记忆以及自己动手能力,存在错误的地方,大家多多交流。如果对你有必定的协助,麻烦点个赞!