【筆記】Python的資料型態:list、tuple(下)

更新於 發佈於 閱讀時間約 11 分鐘
延續上一篇


常使用的函式

sort

對原始串列進行排序

numbers = [3, 1, 4, 2, 5]
numbers.sort()
print(numbers)

----結果----
[1, 2, 3, 4, 5]


跟它很相似函數 sorted,它不會修改原始串列,而是新增一個修改後的串列

numbers = [3, 1, 4, 2, 5]
sort_numbers = sorted(numbers)
print(sort_numbers)

----結果----
[1, 2, 3, 4, 5]


reverse

反轉中元素的順序

numbers = [3, 1, 4, 2, 5]
numbers.reverse()
print(numbers)

----結果----
[5, 2, 4, 1, 3]


如果不想要改變原本的資料,可以用下面這種方法

numbers = [3, 1, 4, 2, 5]
numbers_reverse = numbers[::-1]
print(numbers_reverse)

----結果----
[5, 2, 4, 1, 3]

第一個":"表示串列開頭

第二個":"表示串列結尾

"-1"代表從後面數過來

總體就會是串列從頭到尾,從後面數過來,就可以達到reverse的效果了


count

統計指定元素出現的次數,如果指定的元素不存在,則返回0

numbers = [3, 1, 4, 2, 5, 5, 5, 5, 5, 3, 2, 1, 4, 3, 5]
count_5 = numbers.count(5)
count_0 = numbers.count(0)

print(f"5總共出現:{count_5}次")
print(f"0總共出現:{count_0}次")

----結果----
5總共出現:6
0總共出現:0

因為沒有改變任何的資料結構,所以串列跟元組都可以用


len

用來獲取元素長度或個數

numbers = [3, 1, 4, 2, 5, 5, 5, 5, 5, 3, 2, 1, 4, 3, 5]
len_numbers = len(numbers)
print(len_numbers)

----結果----
15


index

用來查找指定元素或是子字串第一次出現的位置,如果指定的元素不存在,引發ValueError

numbers = [3, 1, 4, 2, 5, 5, 5, 5, 5, 3, 2, 1, 4, 3, 5]
numbers_index_1 = numbers.index(1)
numbers_index_9 = numbers.index(9)
print(f"1的位置在:第{numbers_index_1}")
print(f"9的位置在:第{numbers_index_9}")
----結果----
1的位置在:第1

----結果----
ValueError: 9 is not in list


如果要找出所有的"1",可以利用for迴圈跟enumerate函數,enumerate 用來遍歷可疊代對象,返回時除了會返回元素本身以外,還會返回位置

numbers = [3, 1, 4, 2, 5, 5, 5, 5, 5, 3, 2, 1, 4, 3, 5]

# 查找數值
target_value = 1

# 用來存放找到的索引位置
numbers_of_1 = []

for index, value in enumerate(numbers):
if value == target_value:
numbers_of_1.append(index)

#計算找到幾個1​
count_of_1 = len(numbers_of_1)

print(f"1的位置在第{numbers_of_1}個")
print(f"找到{count_of_1}個1")

----結果----
1的位置在第[1, 11]
找到21


copy

淺複製,創建一個已有對象的拷貝,比如串列、元組的資料型態,複製後是一個獨立的對象,修改這個對象不會對原始資料造成影響,對於嵌套的資料,如子串列,仍然是資訊共享

numbers = [3, 1, 4, 2, 5]
copy_numbers = numbers.copy()

print(numbers)
print(copy_numbers)

----結果----
[3, 1, 4, 2, 5]
[3, 1, 4, 2, 5]


修改嵌套的資料,會一起更動,因為copy是引用過去的

numbers = [3, 1, [4, 2], 5]
copy_numbers = numbers.copy()
numbers[2][1]= 100

print(numbers)
print(copy_numbers)

----結果----
[3, 1, [4, 100], 5]
[3, 1, [4, 100], 5]


這時可以使用deepcopy(深複製)解決這個問題

# 需要使用copy模組的 deepcopy​
import copy

numbers = [3, 1, [4, 2], 5]
copy_numbers = numbers.copy()
deep_copy_numbers = copy.deepcopy(numbers)
numbers[2][1]= 100

print(f"被修改後的原始資料:{numbers}")
print(f"同步更改的的淺複製資料:{copy_numbers}")
print(f"沒有更改的的深複製資料:{deep_copy_numbers}")

----結果----
被修改後的原始資料:[3, 1, [4, 100], 5]
同步更改的的淺複製資料:[3, 1, [4, 100], 5]
沒有更改的的深複製資料:[3, 1, [4, 2], 5]


sum

用來處理可疊代對象的數學計算,包含整數或是浮點數,字串的話會出現Type Error

numbers = [3, 1, 4, 2, 5]
total = sum(numbers)
print(total)

----結果----
15


1加到100

total = sum(range(1, 101))
print(total)

----結果----
5050


字串合在一起的話可以這樣處理

words = ["Hello", " ", "Pikachu"]
result = "".join(words)
print(result)

----結果----
Hello Pikachu


min跟max

用於在一個可疊代對象(如串列、元组、字串等)中找到最小值和最大值

numbers = [5, 1, 8, 2, 9, 3]

min_value = min(numbers)
max_value = max(numbers)

print(f"最小值:{min_value}")
print(f"最大值:{max_value}")

----結果----
最小值:1
最大值:9


從變數中,找到最小值跟最大值

A = 30
B = 85
C = 101

min_value = min(A ,B ,C)
max_value = max(A ,B ,C)

print(f"最小值變數:{min_value}")
print(f"最大值變數:{max_value}")

----結果----
最小值參數:30
最大值參數:101


字串的話,我們可以比長度

pokemon = ["Pikachu", "Charizard", "Squirtle", "Bulbasaur"]
longest_word = max(pokemon, key=len)
shortest_word = min(pokemon, key=len)

print(f"最短的是:{longest_word}")
print(f"最長的是:{shortest_word}")

----結果----
最短的是:Charizard
最長的是:Pikachu


any跟all

檢查可疊代函數中的內容是否為真值,回傳布林值

any:至少有一個數值為真,返回True,否則返回False

all:全部的數值為真,返回True,否則返回False

pokemon = ["Pikachu", "Charizard", "Squirtle", "Bulbasaur", ""]
pokemon_no_numbers = any(pokemon)
print(pokemon_no_numbers)

----結果----
True


如果是用all,在有一個內鬼的情況下就不行了

pokemon = ["Pikachu", "Charizard", "Squirtle", "Bulbasaur", ""]
pokemon_no_numbers = all(pokemon)
print(pokemon_no_numbers)

----結果----
False


增加條件式判斷

numbers = [1, 2, 3, 4, 5]
has_odd = any(x % 2 == 1 for x in numbers)
all_odd = all(x % 2 == 1 for x in numbers)
print(f"至少有一個奇數:{has_odd}")
print(f"全部都是奇數:{all_odd}")

----結果----
至少有一個奇數:True
全部都是奇數:False


如果要讓True跟False改成回文字的話,加入if else判斷式

numbers = [1, 2, 3, 4, 5]
has_odd = any(x % 2 == 1 for x in numbers)
all_odd = all(x % 2 == 1 for x in numbers)

has_odd_str = "是" if has_odd else "否"
all_odd_str = "是" if all_odd else "否"

print(f"至少有一個奇數:{has_odd_str}")
print(f"全部都是奇數:{all_odd_str}")

----結果----
至少有一個奇數:是
全部都是奇數:否
留言
avatar-img
留言分享你的想法!
avatar-img
冬霞的沙龍
22會員
18內容數
冬霞的沙龍的其他內容
2023/10/22
用程式協助尋找殖利率跟可以進場的點位
Thumbnail
2023/10/22
用程式協助尋找殖利率跟可以進場的點位
Thumbnail
2023/10/15
利用git把檔案推到github上
Thumbnail
2023/10/15
利用git把檔案推到github上
Thumbnail
看更多
你可能也想看
Thumbnail
孩子寫功課時瞇眼?小心近視!這款喜光全光譜TIONE⁺光健康智慧檯燈,獲眼科院長推薦,網路好評不斷!全光譜LED、180cm大照明範圍、5段亮度及色溫調整、350度萬向旋轉,讓孩子學習更舒適、保護眼睛!
Thumbnail
孩子寫功課時瞇眼?小心近視!這款喜光全光譜TIONE⁺光健康智慧檯燈,獲眼科院長推薦,網路好評不斷!全光譜LED、180cm大照明範圍、5段亮度及色溫調整、350度萬向旋轉,讓孩子學習更舒適、保護眼睛!
Thumbnail
創作者營運專員/經理(Operations Specialist/Manager)將負責對平台成長及收入至關重要的 Partnership 夥伴創作者開發及營運。你將發揮對知識與內容變現、影響力變現的精準判斷力,找到你心中的潛力新星或有聲量的中大型創作者加入 vocus。
Thumbnail
創作者營運專員/經理(Operations Specialist/Manager)將負責對平台成長及收入至關重要的 Partnership 夥伴創作者開發及營運。你將發揮對知識與內容變現、影響力變現的精準判斷力,找到你心中的潛力新星或有聲量的中大型創作者加入 vocus。
Thumbnail
List 清單 和 Tuple元組 清單在Python裡面非常的常用,大家一定要熟練這些基礎的元素。 在Python中,列表(List)是一種常用的資料類型,用於儲存一組有序的元素。列表是可變的(Mutable),這意味著你可以在列表中新增、刪除和修改元素。列表使用方括號 []
Thumbnail
List 清單 和 Tuple元組 清單在Python裡面非常的常用,大家一定要熟練這些基礎的元素。 在Python中,列表(List)是一種常用的資料類型,用於儲存一組有序的元素。列表是可變的(Mutable),這意味著你可以在列表中新增、刪除和修改元素。列表使用方括號 []
Thumbnail
sort reverse count index copy len min max sum any all
Thumbnail
sort reverse count index copy len min max sum any all
Thumbnail
題目:在此 kata 中,您將創建一個包含列表並返回具有相反順序的列表的函數。範例(輸入->輸出) * [1, 2, 3, 4] -> [4, 3, 2, 1] * [9, 2, 0, 7] -> [7, 0, 2, 9]
Thumbnail
題目:在此 kata 中,您將創建一個包含列表並返回具有相反順序的列表的函數。範例(輸入->輸出) * [1, 2, 3, 4] -> [4, 3, 2, 1] * [9, 2, 0, 7] -> [7, 0, 2, 9]
Thumbnail
題目的輸入會給我們一個串列,要求我們從頭到尾反轉整個串列。 例子: 如果輸入是1 -> 2 -> 3,那麼輸出就是 3 -> 2 -> 1
Thumbnail
題目的輸入會給我們一個串列,要求我們從頭到尾反轉整個串列。 例子: 如果輸入是1 -> 2 -> 3,那麼輸出就是 3 -> 2 -> 1
Thumbnail
這題就是經典的考排序驗算法, 不管在教科書、上機考、面試白板題都是一個很基本又滿熱門的題目。 題目會給定一個輸入陣列,要求我們實作一個排序演算法,把陣列元素從小到大排好。
Thumbnail
這題就是經典的考排序驗算法, 不管在教科書、上機考、面試白板題都是一個很基本又滿熱門的題目。 題目會給定一個輸入陣列,要求我們實作一個排序演算法,把陣列元素從小到大排好。
Thumbnail
list跟tuple 應用場景跟常用函式:append extend insert remove clear pop del
Thumbnail
list跟tuple 應用場景跟常用函式:append extend insert remove clear pop del
Thumbnail
在 C# 中,List 是一個常見且實用的集合類型,可以儲存一組元素並進行各種操作。本篇教學將帶你深入了解如何操作 List 以及進行降冪排序。我們將使用一系列範例程式碼來說明這些概念。
Thumbnail
在 C# 中,List 是一個常見且實用的集合類型,可以儲存一組元素並進行各種操作。本篇教學將帶你深入了解如何操作 List 以及進行降冪排序。我們將使用一系列範例程式碼來說明這些概念。
Thumbnail
Hi,大家好。我是茶桁。 最近几节课,我们都是在详细讲解Python内的数据类型,上一节课我们详细了解了字符串,这节课,让我们来详解一下列表。 首先,我们先有一个大的概念,列表,其实就是一组有序的数据组合;另外,列表中的数据是可以被修改的。也就是说,列表是一个可变序列类型。 列表定义 如何在
Thumbnail
Hi,大家好。我是茶桁。 最近几节课,我们都是在详细讲解Python内的数据类型,上一节课我们详细了解了字符串,这节课,让我们来详解一下列表。 首先,我们先有一个大的概念,列表,其实就是一组有序的数据组合;另外,列表中的数据是可以被修改的。也就是说,列表是一个可变序列类型。 列表定义 如何在
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News