列表为容器类型**可变可异构可嵌套**对象,可以通过索引访问列表元素。
## 定义列表的方式
~~~
list1 = []
list1 = list()
~~~
## 原处修改
实际上是修改**元素引用**
### 修改指定索引的元素
`list1[1] = 2` --> 修改列表的第2个元素
### 修改指定的分片
`list1[2:4] = [3, 4]` --> 修改列表的第3,4个元素
### 删除指定索引的元素
`list1[1:2] = []` --> 删除列表的第2个元素
`del list1[1]` --> 删除列表的第2个元素
`del(list1[1])` --> 删除列表的第2个元素
### 删除指定的分片
`list1[1:3] = [] `--> 删除列表的第2,3个元素
### 指定步长
`l[0:-1:2] == l[::2]` --> 获取部分元素
## 适用于列表的操作 内置方法
### 追加
`L.append(object)` -> append object to end:将对象作为元素追加到列表
`L.extend(iterable)` -> extend list by appending elements from the iterable:将可迭代对象的元素附加到列表
> L.append(X) <==> L[len(X):] = [X]
### 插入
`L.insert(index, object)` -- insert object before index 在指定位置之前插入一个元素
### 删除
`L.pop([index])` -> item -- remove and return item at index (default last)删除指定索引的元素IndexError
`L.remove(value)` --> remove first occurrence of value.删除指定值的元素ValueError
### 计数
`L.count(value)` -> integer -- return number of occurrences of value 统计指定值出现的次数
### 排序
`L.sort(key=None, reverse=False)`正向原处排序
`L.reverse()` --> reverse *IN PLACE* **逆向原处排序**
### 查找
`L.index(value, [start, [stop]])` -> integer -- return first index of value.
查找列表元素**第一次**出现的位置ValueError
## 列表复制
### 完全同步
赋值后实际指向同一个内存对象,两个是**同步**的
~~~
l2 = l1
~~~
### 外层不同步,内层同步
~~~
l2 = l1.copy()
l3 = l1[:]
l4=list(l1)
l5 = [ i for i in l2 ]
~~~
### 完全复制
深度复制(copy模块),复制后的列表和原列表没有任何关系
~~~
l6 = copy.deepcopy(l1)
~~~
## 列表解析
### 生成列表
```python
[ord(x) for x in 'Spaam']
[83, 112, 97, 97, 109]
```
### 生成集合
```python
{ord(x) for x in 'Spaam'}
{83, 97, 109, 112}
```
### 生成字典
```python
{x: ord(x) for x in 'Spaam'}
{'S': 83, 'a': 97, 'm': 109, 'p': 112}
```
### 生成器
```python
M = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
G = (sum(row) for row in M)
G
G.netx() #用来访问
<generator object <genexpr> at 0x7fbd8387c910>
```
### 列表解析和for循环
```python
squares = [ x ** 2 for x in [1, 2, 3]]
for x in [1, 2, 3]:
squares.append(x ** 2)
```
通常优势考虑使用列表解析,速度快于for循环
- 前言
- 环境搭建
- pypi
- 打包
- Python 2 和 Python 3 的版本之间差别
- 项目
- 第一部分
- 第1章 基础
- Python安装
- python代码文件类型
- python对象
- 核心数据类型
- 核心数据类型--整型和浮点型
- 核心数据类型--字符串
- str.format
- 核心数据类型--列表
- 核心数据类型--元组
- 核心数据类型--字典
- 核心数据类型--集合
- 核心数据类型--文件对象
- 调用bash
- 标准输入输出
- str-repr
- 字符编码
- 迭代器和生成器
- 第2章 语句和语法
- 赋值语句
- if语句
- while语句
- for语句
- assert
- 第3章 函数
- 函数作用域
- 工厂函数
- 内置函数
- 递归
- 嵌套作用域和lambda
- 参数传递
- 函数式编程
- property可写与可读
- 第5章 模块
- 模块导入
- 模块命名空间
- 相对导入和绝对导入
- 模块重载
- 在模块中隐藏数据
- 过渡性重载
- 第6章 类
- 面向对象还是面向过程?
- 构造函数 析构函数
- call
- 运算符重载
- str()
- 待定
- 即时生成属性
- 多态
- 线程和进程
- thread模块
- threading模块
- threading线程锁
- 糖果机
- multiprocessing
- 阻塞非阻塞同步异步
- 单线程和多线程对比
- 生产者消费者模型
- 第二部分
- 获取系统资源信息
- 获取进程所占的物理内存
- dmidecode获取系统信息
- 网络编程
- 网络基础
- python中的套接字
- socket模块
- 第三部分 高级功能
- 闭包入门
- 闭包的应用
- 装饰器入门
- 装饰器应用
- 第四部分 项目实战
- graphite
- 模块
- collections
- datetime
- Enum
- faker
- fabric
- fileinput
- fire
- fnmatch
- getpass
- glob
- hashlib
- heapq
- json模块
- log
- os
- Paramiko
- parser
- platform
- pyyaml
- Queue
- random
- re
- 特殊符号和字符
- re模块
- shelves
- subprocess
- time
- urllib_urllib2_requests
- urllib urllib2
- requests
- 标准模块ConfigParser
- 扩展模块Mysqldb
- 扩展模块dns
- 扩展模块request
- uuid
- cacheout 缓存库
- delorean 时间
- 附录
- 内置函数
- python实现各种排序算法
- 常见报错
- pymongo
- pyrocksdb
- 常用
- ERROR