如果想要存所有 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

接下來有沒有辦法一次就把 StarkThor 給取出來?

#!/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

又不對了,別忘記了,切片取值是顧頭不顧尾, 所以才會取出 ThorLoki,那在修改一下,參考下圖說明

#!/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了,這就是取代,那再來要怎麼刪除人名嗎?總共三種方法,這次刪除都以位置為 1Coulson 做示範

#!/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 基礎 - 列表的使用的更多相关文章

  1. Python 基礎 - 列表的使用_v2

    接下來繼續講之前沒提到的 copy(),我們依續之前的列表,來做觀察,看看使用 copy() 有什麼不一樣? #!/usr/bin/env python3 # -*- coding:utf-8 -*- ...

  2. Python 基礎 - for流程判斷

    今天介紹另一個循環判斷式 for循環,首先,先寫一個很簡單的 for循環的代碼 #!/usr/bin/env python3 # -*- coding:utf-8 -*- for i in range ...

  3. Python 基礎 - if else流程判斷

    hmm~前面講了那麼多,終於可以稍稍的正式進入另一個階段,沒錯,要開始寫判斷式了 這次先從最簡單的判斷式開始,if else 開始- Go 首先,之前有寫有一個簡單的互動式 用戶輸入 的代碼,忘記了嗎 ...

  4. Python 基礎 - 數據類型

    標準數據類型 Python3 中有六個標準的數據類型 1 Number(數字) 2 String(字符串) 3 List (列表) 4 Tuple (元組) 5 Sets (集合) 6 Diction ...

  5. Python 基礎 - 文件的操作

    在來我們來玩一下文件操作,這個在未來工作上,也是會很常用到的功能 Python2.7中,可以用file()來打開文件,而在Python3中,一律都是用open(),接下來在當前目錄下,先建立一個空文件 ...

  6. Python 基礎 - 字典的操作使用

    接下來介紹字典,這在未來工作上,會是很常使用的,就來好好了解一下唄- 字典是一個 key(鍵)-value(值) 的數據類型,可以儲存很多訊息 #!/usr/bin/env python3 # -*- ...

  7. Python 基礎 - 字符串常用操作

    字符串常用操作 今天就介紹一下常用的字符串操作,都是以 Python3撰寫的 首字母變大寫 #!/usr/bin/env python3 # -*- coding:utf-8 -*- name = & ...

  8. Python 基礎 - 淺copy補充說明

    在 import copy 這個模塊裡 基於第一個列表來做淺copy,實際上第二個列表裡的元素,是第一個列表的 引用. 接下來介紹 淺copy有三種方式可以使用 #!/usr/bin/env pyth ...

  9. Python 基礎 - 字符編碼

    Python 解釋器在加載 .py 文件中的代碼時,會對內容進行編碼 (默認 ascill) ASCII (American Standard Code for Information Interch ...

随机推荐

  1. 【图像处理】【SEED-VPM】5.uImage的烧写 & NFS烧写文件系统

    基于 TFTP 烧写 uImage 当用户对 SEED-VPM6467 下的内核驱动源码进行调整或者添加新的设备驱动后,需要对内核进行重新编译配置,编译生成内核镜像后,可以通过 tftp 下载到 SE ...

  2. 【 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 ...

  3. twrp编译步骤 (CWM也差不多)

    1.源码的跟目录执行:. build/envsetup.sh,构建编译环境 2.执行 make -j4 otatools,生成后面编译需要的工具 3.把boot或recovery放到home目录,执行 ...

  4. 用JS修改checkbox的选中状态

    代码如下: <SCRIPT LANGUAGE="JavaScript"> <!-- function change() { var c=document.myfo ...

  5. String Mybatis 多数据源配置

    做项目用到了多数据源的配置,有时候不用就忘记了,自己做下备份以防止忘记. 在配置文件中: <bean id="ds1" class="org.apache.comm ...

  6. list内容按长度等分

    这里需要导入 from more_itertools import chunked chunked(iterable, n) 将一个可迭代对象等分成n个list,第n个list的长度可能小于之前的. ...

  7. Javascript DOM编程艺术 2宿主对象

    区别于Javascript脚本里的预先定义好的对象,宿主对象不是由Javascript语言本身提供的(内建对象)和用户自定义对象,它是由Javascript的运行环境(如web浏览器)提供的.这种We ...

  8. memo的一般方法

    str := '好时代卡卡卡的水平佛单师傅开锁'; Memo1.Lines.Add(str); // 在最后加一行字符串 Memo1.Lines.Delete(x); // 删除x+1行字符串 Mem ...

  9. HighChats图表控件显示精度小数点的方法

    相信大家对highchats这个图表控件并不陌生,最近在项目中用到它,但是某些字段需要显示为小数点,顾查找资料文档发现下面两个方式可以实现: 初始化时候添加如下两个参数 tooltip:{    fo ...

  10. Sqlite日期类型问题:该字符串未被识别为有效的 DateTime(String not recognized as a valid datetime)

    使用SQLite抛出异常: 该字符串未被识别为有效的 DateTime 错误(String not recognized as a valid datetime) 解决方法: 也可以在连接字符串 修改 ...