Python 基礎 - 列表的使用
如果想要存所有 Marvel's The Avengers 角色的人名,該如何存呢?請用目前已學到的知識來實做…
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
目前已存了五個人,透過空白來區分(也可以用逗號),但該如何去取某一個人的值!?因為咱們已經把這五個人的人名存在一個變量裡了,所以沒辦法取,除非…可以像 Shell Script 透過 sed or awk 去做區分(喂~不能這樣做),想改也沒辦法改,實務上,我們想存很多的訊息,並且透過字符串來存,就面臨了二個問題,一是不好存,二是不好改,所以後來發展出了新的數據類型,就叫 列表
,在 Python 裡,使用列表時,就請用 [](中括號)
。
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = []
print(names)
---------------執行結果---------------
[]
Process finished with exit code 0
這樣就打印出來一個空的列表,接下來把剛剛的人名給存在這列表裡吧…
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names)
---------------執行結果---------------
['Rogers', 'Stark', 'Thor', 'Loki', 'Natasha']
Process finished with exit code 0
這樣就把人名存進去了,接下來我們來取其中一個人名好了,抓 Rogers
好了,該怎麼取呢?
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names["Rogers"])
---------------執行結果---------------
Traceback (most recent call last):
File "/Users/ironman/python/names.py", line 7, in <module>
print(names["Rogers"])
TypeError: list indices must be integers or slices, not str
Process finished with exit code 1
結果發現報錯 TypeError: list indices must be integers or slices, not str
,是因為不能這樣取值的,正確取值應該是…
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names[0])
---------------執行結果---------------
Rogers
Process finished with exit code 0
這樣就取出來了,但為什麼會是0呢? 0
就代表 Rogers
在這個列表中,從左到右開始的第一個位置,但在電腦存數據時,不是從1開始算的,是從0開始算起的,因為二進制使用的第一個狀態就是0,所以從0開始算的,因此,我們可以透過位置來取得相對應的值。
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names[0], names[1])
---------------執行結果---------------
Rogers Stark
Process finished with exit code 0
接下來有沒有辦法一次就把 Stark
跟 Thor
給取出來?
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names[0], names[1])
print(names[1:2])
---------------執行結果---------------
Rogers Stark
['Stark']
Process finished with exit code 0
咦~怎麼只出現 Stark
?那在往後取一位試試…
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names[0], names[1])
print(names[1:3])
---------------執行結果---------------
Rogers Stark
['Stark', 'Thor']
Process finished with exit code 0
哦…這樣就取出來正確的了,那有沒有發現一個問題,就是只有顧到(包括) 起始位置
,而沒有顧到(不包括) 結束位置
,所以我們叫這個是 顧頭不顧尾
,如果你要取的位置是連續的就可以用這個方式,而這個方式就叫做 slices(切片)
。
假設今天我有一個很長的列表,不知道有幾個,但想取最後一個,該怎麼取呢?我們依上面的代碼,先取出最後一個值
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names[0], names[1])
print(names[1:3])
print(names[4]) # 在已知可數的情況下,就是我們一般取最後一個值的用法
---------------執行結果---------------
Rogers Stark
['Stark', 'Thor']
Natasha
Process finished with exit code 0
在不可數的情況下,也是一般較常用的寫法是
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names[0], names[1])
print(names[1:3])
print(names[4])
print(names[-1])
---------------執行結果---------------
Rogers Stark
['Stark', 'Thor']
Natasha
Natasha
Process finished with exit code 0
正的就是從左到右取值,負的就是從右到左取值,那如果接下想要取一次取最後二個值,該怎麼取呢?
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names)
print(names[-1:-3])
---------------執行結果---------------
['Rogers', 'Stark', 'Thor', 'Loki', 'Natasha']
[]
Process finished with exit code 0
為什麼取出空列表哩,主要是因為 切片
還是一樣是 從左往右數
來取得數值的,所以我們應該要寫成-3開始取值
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names)
print(names[-3:-1])
---------------執行結果---------------
['Rogers', 'Stark', 'Thor', 'Loki', 'Natasha']
['Thor', 'Loki']
Process finished with exit code 0
又不對了,別忘記了,切片取值是顧頭不顧尾
, 所以才會取出 Thor
跟 Loki
,那在修改一下,參考下圖說明
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names)
print(names[-2:-1])
---------------執行結果---------------
['Rogers', 'Stark', 'Thor', 'Loki', 'Natasha']
['Loki']
Process finished with exit code 0
又不對了,因為 切片是顧頭不顧尾
,但又想取最後一個值,又該怎麼辦?
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names)
print(names[-2:])
---------------執行結果---------------
['Rogers', 'Stark', 'Thor', 'Loki', 'Natasha']
['Loki', 'Natasha']
Process finished with exit code 0
這樣就取到,有發現嗎?如果要取最後一個數值,其實 省略不打
就可以取到了,那如果要正取0到3,同樣的也是可以省略0,代碼寫法如下
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
print(names)
print(names[:3])
---------------執行結果---------------
['Rogers', 'Stark', 'Thor', 'Loki', 'Natasha']
['Rogers', 'Stark', 'Thor']
Process finished with exit code 0
接下來那我們又想要多加入一個人,該怎麼寫呢?
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
names.append("Barton")
print(names)
---------------執行結果---------------
['Rogers', 'Stark', 'Thor', 'Loki', 'Natasha', 'Barton']
Process finished with exit code 0
append()
意思就是附加,而且是加在最後面的,那如果想要隨意放在列表的任一位置呢?
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
names.append("Barton")
names.insert(1, "Coulson")
print(names)
---------------執行結果---------------
['Rogers', 'Coulson', 'Stark', 'Thor', 'Loki', 'Natasha', 'Barton']
Process finished with exit code 0
insert()
就是插入任意你想要插入的位置,依上例代碼來說,就是要把 Coulson
插入到 Stark
前面,因此,填入的數字就 1
,這樣就會插入在 Stark
前了,那如果要在新增一個人,到 Stark
後面,又要怎麼寫呢?
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
names.append("Barton")
names.insert(1, "Coulson")
names.insert(3, "Fury")
print(names)
---------------執行結果---------------
['Rogers', 'Coulson', 'Stark', 'Fury', 'Thor', 'Loki', 'Natasha', 'Barton']
Process finished with exit code 0
那要怎麼列表中的人名做取代的呢?
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
names.append("Barton")
names.insert(1, "Coulson")
names.insert(3, "Fury")
names[2] = "Bruce"
print(names)
---------------執行結果---------------
['Rogers', 'Coulson', 'Bruce', 'Fury', 'Thor', 'Loki', 'Natasha', 'Barton']
Process finished with exit code 0
有發現了嘛, Stark
被取代成 Bruce
了,這就是取代,那再來要怎麼刪除人名嗎?總共三種方法,這次刪除都以位置為 1
的 Coulson
做示範
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
names.append("Barton")
names.insert(1, "Coulson")
names.insert(3, "Fury")
names[2] = "Bruce"
print(names)
# delete methods
# 1. names.remove("Coulson")
# 2. del names[1] = names.pop(1)
# 3. names.pop(1)
names.pop(1)
print(names)
---------------執行結果---------------
['Rogers', 'Coulson', 'Bruce', 'Fury', 'Thor', 'Loki', 'Natasha', 'Barton']
['Rogers', 'Bruce', 'Fury', 'Thor', 'Loki', 'Natasha', 'Barton']
Process finished with exit code 0
這三個方法都可以用來刪除,其中要特別說明的就是 pop()
這個刪除是最後一個,請看下圖跟代碼
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
names.append("Barton")
names.insert(1, "Coulson")
names.insert(3, "Fury")
names[2] = "Bruce"
print(names)
names.pop()
print(names)
---------------執行結果---------------
['Rogers', 'Coulson', 'Bruce', 'Fury', 'Thor', 'Loki', 'Natasha', 'Barton']
['Rogers', 'Coulson', 'Bruce', 'Fury', 'Thor', 'Loki', 'Natasha']
Process finished with exit code 0
那如果要在列表中,尋找特定的一個人名是在哪一個位置,那該怎麼找呢?這次我們來找 Loki
好了
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
names.append("Barton")
names.insert(1, "Coulson")
names.insert(3, "Fury")
names[2] = "Bruce"
print(names)
print(names.index("Loki"))
---------------執行結果---------------
['Rogers', 'Coulson', 'Bruce', 'Fury', 'Thor', 'Loki', 'Natasha', 'Barton']
5
Process finished with exit code 0
嗯,找到了,但如果我想找出位置後,並打印出相對應的值,該怎麼寫?
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha"]
names.append("Barton")
names.insert(1, "Coulson")
names.insert(3, "Fury")
names[2] = "Bruce"
print(names)
print(names.index("Loki"))
print( names[names.index("Loki")] )
---------------執行結果---------------
['Rogers', 'Coulson', 'Bruce', 'Fury', 'Thor', 'Loki', 'Natasha', 'Barton']
5
Loki
Process finished with exit code 0
那如何在列表中,查詢有相同人名的有幾個?
#!/usr/bin/env python3
# -*- coding:utf-8 -*-
names = "Rogers Stark Thor Loki Natasha"
names = ["Rogers", "Stark", "Thor", "Loki", "Natasha", "Coulson"]
names.append("Barton")
names.insert(1, "Coulson")
names.insert(3, "Fury")
names[2] = "Bruce"
print(names)
print(names.count("Coulson"))
---------------執行結果---------------
['Rogers', 'Coulson', 'Bruce', 'Fury', 'Thor', 'Loki', 'Natasha', 'Coulson', 'Barton']
2
Process finished with exit code 0
Python 基礎 - 列表的使用的更多相关文章
- Python 基礎 - 列表的使用_v2
接下來繼續講之前沒提到的 copy(),我們依續之前的列表,來做觀察,看看使用 copy() 有什麼不一樣? #!/usr/bin/env python3 # -*- coding:utf-8 -*- ...
- Python 基礎 - for流程判斷
今天介紹另一個循環判斷式 for循環,首先,先寫一個很簡單的 for循環的代碼 #!/usr/bin/env python3 # -*- coding:utf-8 -*- for i in range ...
- Python 基礎 - if else流程判斷
hmm~前面講了那麼多,終於可以稍稍的正式進入另一個階段,沒錯,要開始寫判斷式了 這次先從最簡單的判斷式開始,if else 開始- Go 首先,之前有寫有一個簡單的互動式 用戶輸入 的代碼,忘記了嗎 ...
- Python 基礎 - 數據類型
標準數據類型 Python3 中有六個標準的數據類型 1 Number(數字) 2 String(字符串) 3 List (列表) 4 Tuple (元組) 5 Sets (集合) 6 Diction ...
- Python 基礎 - 文件的操作
在來我們來玩一下文件操作,這個在未來工作上,也是會很常用到的功能 Python2.7中,可以用file()來打開文件,而在Python3中,一律都是用open(),接下來在當前目錄下,先建立一個空文件 ...
- Python 基礎 - 字典的操作使用
接下來介紹字典,這在未來工作上,會是很常使用的,就來好好了解一下唄- 字典是一個 key(鍵)-value(值) 的數據類型,可以儲存很多訊息 #!/usr/bin/env python3 # -*- ...
- Python 基礎 - 字符串常用操作
字符串常用操作 今天就介紹一下常用的字符串操作,都是以 Python3撰寫的 首字母變大寫 #!/usr/bin/env python3 # -*- coding:utf-8 -*- name = & ...
- Python 基礎 - 淺copy補充說明
在 import copy 這個模塊裡 基於第一個列表來做淺copy,實際上第二個列表裡的元素,是第一個列表的 引用. 接下來介紹 淺copy有三種方式可以使用 #!/usr/bin/env pyth ...
- Python 基礎 - 字符編碼
Python 解釋器在加載 .py 文件中的代碼時,會對內容進行編碼 (默認 ascill) ASCII (American Standard Code for Information Interch ...
随机推荐
- 【图像处理】【SEED-VPM】5.uImage的烧写 & NFS烧写文件系统
基于 TFTP 烧写 uImage 当用户对 SEED-VPM6467 下的内核驱动源码进行调整或者添加新的设备驱动后,需要对内核进行重新编译配置,编译生成内核镜像后,可以通过 tftp 下载到 SE ...
- 【 2013 Multi-University Training Contest 1 】
HDU 4602 Partition f[i]表示和为i的方案数.已知f[i]=2i-1. dp[i]表示和为i,k有多少个.那么dp[i]=dp[1]+dp[2]+...+dp[i-1]+f[i-k ...
- twrp编译步骤 (CWM也差不多)
1.源码的跟目录执行:. build/envsetup.sh,构建编译环境 2.执行 make -j4 otatools,生成后面编译需要的工具 3.把boot或recovery放到home目录,执行 ...
- 用JS修改checkbox的选中状态
代码如下: <SCRIPT LANGUAGE="JavaScript"> <!-- function change() { var c=document.myfo ...
- String Mybatis 多数据源配置
做项目用到了多数据源的配置,有时候不用就忘记了,自己做下备份以防止忘记. 在配置文件中: <bean id="ds1" class="org.apache.comm ...
- list内容按长度等分
这里需要导入 from more_itertools import chunked chunked(iterable, n) 将一个可迭代对象等分成n个list,第n个list的长度可能小于之前的. ...
- Javascript DOM编程艺术 2宿主对象
区别于Javascript脚本里的预先定义好的对象,宿主对象不是由Javascript语言本身提供的(内建对象)和用户自定义对象,它是由Javascript的运行环境(如web浏览器)提供的.这种We ...
- memo的一般方法
str := '好时代卡卡卡的水平佛单师傅开锁'; Memo1.Lines.Add(str); // 在最后加一行字符串 Memo1.Lines.Delete(x); // 删除x+1行字符串 Mem ...
- HighChats图表控件显示精度小数点的方法
相信大家对highchats这个图表控件并不陌生,最近在项目中用到它,但是某些字段需要显示为小数点,顾查找资料文档发现下面两个方式可以实现: 初始化时候添加如下两个参数 tooltip:{ fo ...
- Sqlite日期类型问题:该字符串未被识别为有效的 DateTime(String not recognized as a valid datetime)
使用SQLite抛出异常: 该字符串未被识别为有效的 DateTime 错误(String not recognized as a valid datetime) 解决方法: 也可以在连接字符串 修改 ...