- >>> li = ["a", "b", "mpilgrim", "z", "example"]
- >>> li
- ['a', 'b', 'mpilgrim', 'z', 'example']
- >>> li[0]
- 'a'
- >>> li[4]
- 'example'
2.負的list 索引
- >>> li
- ['a', 'b', 'mpilgrim', 'z', 'example']
- >>> li[-1]
- 'example'
- >>> li[-3]
- 'mpilgrim'
- >>> li
- ['a', 'b', 'mpilgrim', 'z', 'example']
- >>> li[1:3]
- ['b', 'mpilgrim']
- >>> li[1:-1]
- ['b', 'mpilgrim', 'z']
- >>> li[0:3]
- ['a', 'b', 'mpilgrim']
3.向 list 中增加元素
- >>> li
- ['a', 'b', 'mpilgrim', 'z', 'example']
- >>> li.append("new")
- >>> li
- ['a', 'b', 'mpilgrim', 'z', 'example', 'new']
- >>> li.insert(2, "new")
- >>> li
- ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new']
- >>> li.extend(["two", "elements"])
- >>> li
- ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', 'two', 'elements']
4.搜索 list
- >>> li
- ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', 'two', 'elements']
- >>> li.index("example")
- 5
- >>> li.index("new")
- 2
- >>> li.index("c")
- Traceback (innermost last):
- File "<interactive input>", line 1, in ?
- ValueError: list.index(x): x not in list
- >>> "c" in li
- False
5.從 list 中刪除元素
- >>> li
- ['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', 'two', 'elements']
- >>> li.remove("z")
- >>> li
- ['a', 'b', 'new', 'mpilgrim', 'example', 'new', 'two', 'elements']
- >>> li.remove("new")
- >>> li
- ['a', 'b', 'mpilgrim', 'example', 'new', 'two', 'elements']
- >>> li.remove("c")
- Traceback (innermost last):
- File "<interactive input>", line 1, in ?
- ValueError: list.remove(x): x not in list
- >>> li.pop()
- 'elements'
- >>> li
- ['a', 'b', 'mpilgrim', 'example', 'new', 'two']
remove 僅僅 刪除一個值的首次出現。 在這裏, 'new' 在 list 中出現了兩次, 但 li.remove("new") 只刪除了 'new' 的首次出現。
如果在 list 中沒有找到值, Python 會引發一個異常來響應 index 方法。
pop 會做兩件事: 刪除 list 的最後一個元素, 然後返回刪除元素的值。
6.list 運算符
- >>> li = ['a', 'b', 'mpilgrim']
- >>> li = li + ['example', 'new']
- >>> li
- ['a', 'b', 'mpilgrim', 'example', 'new']
- >>> li += ['two']
- >>> li
- ['a', 'b', 'mpilgrim', 'example', 'new', 'two']
- >>> li = [1, 2] * 3
- >>> li
- [1, 2, 1, 2, 1, 2]
7.使用join鏈接list成爲字符串
- >>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"}
- >>> ["%s=%s" % (k, v) for k, v in params.items()]
- ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
- >>> ";".join(["%s=%s" % (k, v) for k, v in params.items()])
- 'server=mpilgrim;uid=sa;database=master;pwd=secret'
8.分割字符串
- >>> li = ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
- >>> s = ";".join(li)
- >>> s
- 'server=mpilgrim;uid=sa;database=master;pwd=secret'
- >>> s.split(";")
- ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
- >>> s.split(";", 1)
- ['server=mpilgrim', 'uid=sa;database=master;pwd=secret']
注意, 分隔符 (“;”) 被完全去掉了, 它沒有在返回的 list 中的任意元素中出現。
split 接受一個可選的第二個參數, 它是要分割的次數。
9.list的映射解析
- >>> li = [1, 9, 8, 4]
- >>> [elem*2 for elem in li]
- [2, 18, 16, 8]
- >>> li
- [1, 9, 8, 4]
- >>> li = [elem*2 for elem in li]
- >>> li
- [2, 18, 16, 8]
10.dictionary中的解析
- >>> params = {"server":"mpilgrim", "database":"master", "uid":"sa", "pwd":"secret"}
- >>> params.keys()
- ['server', 'uid', 'database', 'pwd']
- >>> params.values()
- ['mpilgrim', 'sa', 'master', 'secret']
- >>> params.items()
- [('server', 'mpilgrim'), ('uid', 'sa'), ('database', 'master'), ('pwd', 'secret')]
- >>> [k for k, v in params.items()]
- ['server', 'uid', 'database', 'pwd']
- >>> [v for k, v in params.items()]
- ['mpilgrim', 'sa', 'master', 'secret']
- >>> ["%s=%s" % (k, v) for k, v in params.items()]
- ['server=mpilgrim', 'uid=sa', 'database=master', 'pwd=secret']
11.列表過濾
- >>> li = ["a", "mpilgrim", "foo", "b", "c", "b", "d", "d"]
- >>> [elem for elem in li if len(elem) > 1]
- ['mpilgrim', 'foo']
- >>> [elem for elem in li if elem != "b"]
- ['a', 'mpilgrim', 'foo', 'c', 'd', 'd']
- >>> [elem for elem in li if li.count(elem) == 1]
- ['a', 'mpilgrim', 'foo', 'c']