如果想要存所有 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. linux 安装mysql两种方式

    yum -y install gcc gcc-c++ ncurses-devel cmake  bison   zlib    zlib-devel libxml  openssl   dtrace ...

  2. Anjs分词器以及关键词抓取使用的方法

    首先介绍一下这个网址非常有用本文所有的关于Anjs起源来自这里请先查看一下 https://github.com/NLPchina/ansj_seg 在本次测试使用的是     import java ...

  3. VS2015快捷键

    Shift+Alt+Enter: 切换全屏编辑 Ctrl+B,T / Ctrl+K,K: 切换书签开关Ctrl+B,N / Ctrl+K,N: 移动到下一书签Ctrl+B,P: 移动到上一书签Ctrl ...

  4. http Content-type对照表

    http://tools.jb51.net/table/http_content_type Content-Type,内容类型,一般是指网页中存在的Content-Type,用于定 义网络文件的类型和 ...

  5. 使用Crowd2.7集成Confluence5.3与JIRA6.1,并安装、破解及汉化,实现单点登录【原创】

      鉴于目前没有针对Crowd.Confluence.Jira安装.集成和破解最新的方法,总结今天安装.破解及集成的经验,编写此文,方便大家进行配置也方便自己以后参考.此文参考多篇破解文章,并经过作者 ...

  6. spout详解

    spout放在每个executer执行,我们先从spoutExecutors的初始化开始往下看,spoutExecutors是在一个worker中管理其中的tasks,在SpoutExecutors的 ...

  7. WordPress程序伪静态规则(Nginx/Apache)及二级目录规则

    在众多CMS程序中,我们使用WORDPRESS还是比较多的,不仅仅是安全度较好,二来在于插件和主题很多,即便对于不会建站技术的用户也很简单的就可以搭建属于自己的网站项目.对于网站我们肯定是需要让有用户 ...

  8. java.io.WriteAbortedException: writing aborted; java.io.NotSerializableException

    问题描述: 严重: IOException while loading persisted sessions: java.io.WriteAbortedException: writing abort ...

  9. Dom学习笔记

    今天老师出了一道面试题目:取到表单里面的textbox的值,两种方法.知道一种,老师说的什么dom,我竟然不知道. 以前学html的时候,老师也重来没有提到dom的概念.javaScript只是学了一 ...

  10. 项目中踩过的坑之-sessionStorage

    总想写点什么,却不知道从何写起,那就从项目中踩过的坑开始吧,希望能给可能碰到相同问题的小伙伴一点帮助. 项目情景: 有一个id,要求通过当前网页打开一个新页面(不是当前页面),并把id传给打开的新页面 ...