1. 程式人生 > >python中陣列的操作

python中陣列的操作

1、Python的陣列分三種類型:
(1) list 普通的連結串列,初始化後可以通過特定方法動態增加元素。
定義方式:arr = [元素]

(2) Tuple 固定的陣列,一旦定義後,其元素個數是不能再改變的。
定義方式:arr = (元素)

(2) Dictionary 詞典型別, 即是Hash陣列。
定義方式:arr = {元素k:v}

2、下面具體說明這些陣列的使用方法和技巧:

(1) list 連結串列陣列
a、定義時初始化

a = [1,2,[1,2,3]]

b、定義時不初始化
一維陣列:
arr = []

多維陣列:
arr = [i for i in range(10), 1,[]] #注意, i for in xx 這個必須放在第一個位置,否則要先定義i,

如:
arr = [i for i in range(5), j for j in range(5), []]

這是錯誤的
i = 0
j = 0
arr = [i for i in range(5), j for j in range(5), []]

這是正確的

c、del 語句 和 : 的用法
可以用 start : end 表示數組裡的一個區間 ( i >= start and i < end)
del 刪除數組裡的指定元素
如: del arr[0]
        del arr[0, 2]
       newarr = arr[0, 2]

d、遍歷陣列:
for k, v in enumerate(arr):
        print k, v

e、增加元素:
一維
arr.append(‘aaa’)
二維
arr[0].append(‘aaa’)
如果要在任意位置插入用 arr.insert(n, 值)
此外還有一種特殊的用法是:
arr += [陣列元素]
在不指定下標的情況下,是允許用 += 增加陣列元素的。

(2) Tuple 固定陣列

Tuple 是不可變 list,一旦建立了一個 tuple 就不能以任何方式改變它。
下面拿具體示例說明:
>>> t = (“a”, “b”, “c”, “d”, “e”)              #[1] 用小括號包圍來定義
>>> t
(‘a’, ‘b’, ‘c’, ‘d’, ‘e’)
>>> t[0]                                       #[2] 直接列出某下標的元素
‘a’
>>> t[-1]                                      #[3] 負數表示,從後面倒數的索引 -1 為倒數第一個, 0是順數第一個
‘example’
>>> t[1:3]                                     #[4] 這裡 1:3 是 i>=1 and i<3 的區間
(‘b’, ‘mpilgrim’)

Tuple 沒有的方法:
[1] 不能向 tuple 增加元素,沒有 append 、 extend 、insert 等方法。
[2] 不能從 tuple 刪除元素,沒有 remove 或 pop 方法。
[3] 不能在 tuple 中查詢元素,沒有 index 方法(index是查詢而不是索引,索引直接用下標即可,如:t[0])。

使用 tuple 的好處:
* Tuple 比 list 操作速度快。如果您定義了一個值的常量集, 並且唯一要用它做的是不斷地遍歷它, 請使用 tuple 代替 list。
* 如果對不需要修改的資料進行 “防寫”, 可以使程式碼更安全。使用 tuple 而不是 list 如同擁有一個隱含的 assert 語句, 說明這一資料是常量。如果必須要改變這些值, 則需要執行 tuple 到 list 的轉換 (需要使用一個特殊的函式)。
* 還記得我說過 dictionary keys 可以是字串, 整數和 “其它幾種型別”嗎? Tuples 就是這些型別之一。 Tuples 可以在 dictionary 中被用做 key, 但是 list 不行。實際上, 事情要比這更復雜。Dictionary key 必須是不可變的。Tuple 本身是不可改變的, 但是如果您有一個 list 的 tuple, 那就認為是可變的了, 用做 dictionary key 就是不安全的。只有字串, 整數或其它對 dictionary 安全的 tuple 才可以用作 dictionary key。

Tuple 可以轉換成 list, 反之亦然。
轉換方式為:
t = list( t )
反之:
arr = tuple( arr )

(2) Dictionary (雜湊陣列)詞典陣列


相關推薦

python陣列(numpy.array)的基本操作

本文部分內容參考Daetalus的部落格。 為什麼要用numpy Python中提供了list容器,可以當作陣列使用。但列表中的元素可以是任何物件,因此列表中儲存的是物件的指標,這樣一來,為了儲存

python陣列操作

1、Python的陣列分三種類型: (1) list 普通的連結串列,初始化後可以通過特定方法動態增加元素。 定義方式:arr = [元素] (2) Tuple 固定的陣列,一旦定義後,其元素個數是不能再改變的。 定義方式:arr = (元素) (2) Dictionary 詞典型別, 即是Hash陣列

python關於操作時間的方法(二):使用datetime模塊

log time模塊 bsp lib .py nth mon target ear 使用datetime模塊來獲取當前的日期和時間 1 import datetime 2 i=datetime.datetime.now() 3 print ("當前的日期和時間是%

Python常用操作字串的函式與方法總結

本文轉載自:https://www.jb51.net/article/79196.htm Python中常用操作字串的函式與方法總結 這篇文章主要介紹了Python中常用操作字串的函式與方法總結,包括字串的格式化輸出與拼接等基礎知識,需要的朋友可以參考下 例如這樣一個字串 Python,

Python陣列矩陣的翻轉(翻轉180度,向左翻轉90度,向右翻轉90度)

Python中陣列矩陣的翻轉(翻轉180度,向左翻轉90度,向右翻轉90度) 轉載請表明原處:https://blog.csdn.net/kane7csdn/article/details/83928848 先定義陣列: a = np.array(([1, 2, 3], [4, 5,

Python路徑操作

目錄 1. os.path模組 2. pathlib模組 2.1 目錄操作 2.2 檔案操作 3. shutil模組 3.1 os模組 3.2 shutil模組 1. os.path模組 3.4版本之前使用os.path

js陣列操作常見函式forEach,map,reduce,filter,slice

var a = [1,22,333,4444,55555] function Counter() { this.sum = 0; } js中運算元組的常見函式有: forEach((ite

python檔案操作的基本方法

在python中對一個檔案進行操作,分為三大步:開啟,操作,關閉 首先建立一個檔案hello,裡面內容為hello world 一、開啟一個檔案 #open(‘檔名或檔案路徑’,‘操作模式’,檔案裡內容變成utf-8) 二、對檔案進行相關操作 1.閱讀檔案內容 w=open('hello','r'

Python陣列按行儲存,與Matlab不同

陣列因為是線性結構,因此在記憶體中都是順序儲存的,但按行儲存還是按列儲存,不同語言有不同的規定。matlab是按列儲存的,而C/C++和python是按行儲存的 。 以二維陣列為例: #python import numpy as np >>

python檔案操作總結

1.open:開啟檔案並且返回檔案的操作物件 f=open(“檔名”,“訪問方式”)          注:不寫訪問方式,預設只讀模式。   注:頻繁的移動檔案指標,會影響檔案的讀寫效率,開發中更多的時候會以 只讀、只寫 的方式

python陣列的使用

1、Python的陣列分三種類型: (1) list 普通的連結串列,初始化後可以通過特定方法動態增加元素。 定義方式:arr = [元素] (2) Tuple 固定的陣列,一旦定義後,其元素個數是不能再改變的。 定義方式:arr = (元素) (2) Dictionary 詞典型別, 即是Hash陣列。

pythonselenium操作下拉滾動條方法彙總

UI自動化中經常會遇到元素識別不到,找不到的問題,原因有很多,比如不在iframe裡,xpath或id寫錯了等等;但有一種是在當前顯示的頁面元素不可見,拖動下拉條後元素就出來了。 在python中有幾種方法解決這種問題,簡單介紹下,給需要的人: 方法一)使用

pythoncursor操作資料庫

cursor用來執行命令的方法:callproc(self, procname, args):用來執行儲存過程,接收的引數為儲存過程名和引數列表,返回值為受影響的行數execute(self, query, args):執行單條sql語句,接收的引數為sql語句本身和使用的引數列表,返回值為受影響的行數exe

Python陣列及矩陣的大小

在上篇博文中介紹了python中常見的二維陣列:list與numpy.array。在很多情況下我們需要獲取陣列的大小,閱讀過一些python程式碼可以發現,常見的方法一般有len, size, shape這三種,那麼這三種方法分別應用於那些場合?有什麼區別?本文將通過示例來探討這些問題。

pythonlist操作詳解

1.定義list >>> li = ["a", "b", "mpilgrim", "z", "example"] >>> li ['a', 'b', 'mpilgrim', 'z', 'example'] >>> li[

python陣列去重

source = ['a','a','b','c','d','d'] dest = [] for e in source: if e not in dest: dest.appe

python移位操作 問題

一、現象 Python 中執行左移操作(即將一個數的二進位制位整體向左移若干位,移位後在低位補零,高位溢位部分捨棄): >>> 1000<<25結果是:33554432000L 而在 C#、C++等語言中執行同樣的左移操作,結果卻迥然不同: C

Python檔案操作

1 檔案操作   無論在那種語言中都會對檔案進行操作處理,而檔案相關的處理無非就是開啟檔案,讀取或者寫入內容,最後再是關閉檔案。ython中檔案常用的IO操作有以下幾個: Function Operation open 開啟 read 讀取 write 寫入 close 關閉 rea

Java陣列操作 java.util.Arrays 類常用方法的使用

任何一門程式語言,陣列都是最重要和常用的資料結構之一,但不同的語言對陣列的構造與處理是不盡相同的。 Java中提供了java.util.Arrays 類能方便地運算元組,並且它提供的所有方法都是靜態的。下面介紹一下Arrays類最常用的幾個方法。 1.  陣列排序 Arrays工具類提供了一個sor

Pythonnumpy 陣列的切片操作

簡介 X[n0,n1]是通過 numpy 庫引用二維陣列或矩陣中的某一段資料集的一種寫法。 類似的,X[n0,n1,n2]表示取三維陣列,取N維陣列則有N個引數,N-1個逗號分隔。 以二維陣列為例: import numpy as np X = np.arra