Ⅰ 如何在python的列表中添加變數
#因為直接向列表添加變數是會將變數的值添加到list裡面,而不是將變數名添加到list裡面
#所以可嘗試以下做法
#定義變數
a=1
b=2
c=3
d=4
#添加變數的字元串名字
vars=[]
vars.append("a")
vars.append("b")
vars.append("c")
vars.append("d")
#也可以直接
#vars=["a","b","c","d"]
#訪問變數採用locals()[v],v是變數的字元串形式
forvinvars:
print(v,locals()[v])
Ⅱ python中,如何將list中的各個值快速賦值給變數
Python 的強大特性之一是其對 list 的解析,它提供一種緊湊的方法,可以通過對 list 中的每個元素應用一個函數,從而將一個 list 映射為另一個 list。
例 3.24. List 解析介紹
>>> li = [1, 9, 8, 4]
>>> [elem*2 for elem in li]
[2, 18, 16, 8]
>>> li
[1, 9, 8, 4]
>>> li = [elem*2 for elem in li]
>>> li
[2, 18, 16, 8]
為了便於理解它,讓我們從右向左看。li 是一個將要映射的 list。Python 循環遍歷 li 中的每個元素。對每個元素均執行如下操作:首先臨時將其值賦給變數 elem,然後 Python 應用函數 elem*2 進行計算,最後將計算結果追加到要返回的 list 中。
需要注意是,對 list 的解析並不改變原始的 list。
將一個 list 的解析結果賦值給對其映射的變數是安全的。不用擔心存在競爭情況或任何古怪事情的發生。Python 會在內存中創建新的 list,當對 list 的解析完成時,Python 將結果賦給變數。
From <dive into python>
Ⅲ python標准數據類型有哪些
python標准數據類型有哪些?
python標准數據類型有:
Number(數字)
String(字元串)
List(列表)
Tuple(元組)
Set(集合)
Dictionary(字典)
Python3的六個標准數據類型中:
不可變數據(3 個):Number(數字)、String(字元串)、Tuple(元組);
可變數據(3 個):List(列表)、Dictionary(字典)、Set(集合)。
相關推薦:《Python教程》以上就是小編分享的關於python標准數據類型有哪些的詳細內容希望對大家有所幫助,更多有關python教程請關注環球青藤其它相關文章!
Ⅳ Python中內置的數據結構都有什麼
python中常見的結構有對象(object)、數組、元組、series以及普通變數。衍生包常見對象有numpy中的narray、pandas中的dataframe等。python中沒有區分字元串、整形數字、字元、浮點型的變數,統一都可以直接賦值。比如a="skkk",a=1,a=1.2222等;數組為a=[1,2,3,4];元組也稱字典類型為a={1:2,2:3}。
Ⅳ python中變數的引用、可變和不可變類型、局部變數和全局變數
變數的引用
變數和數據都是保存在內存中的
變數和數據是分開存儲的
數據保存在內存中某個位置,通過地址來標記
變數保存的是數據的地址,通過地址可以找到數據在內存空間的位置
把變數保存數據地址的過程稱為引用
變數的重新賦值修改的是變數中引用數據的內存地址
變數之間的賦值實際是引用的傳遞
函數參數的傳遞,本質也是引用的傳遞
函數的返回值本身也是引用的傳遞
可變和不可變類型
不可變類型,內存中的數據不允許被修改:數字類型(int,bool,float,complex,long(2,x)、字元串、元組(tuple)
可變類型,內存中的數據可以被修改:列表list、字典dict
無論是可變還是不可變數據類型,通過賦值語句,都會改變變數的引用
Hash函數只能接收不可變數據類型,字典的鍵也只能是不可變數據類型,字典的value值可以是任意數據類型
局部變數
1.在函數內部定義的變數就是局部變數(作用范圍只能是當前函數內部)
2.在函數外部無法直接訪問局部變數
3.不同的函數中可以定義同名的局部變數
4.局部變數的生命周期:從定義變數時開始,到函數運行結束
全局變數
1.在所有函數外邊定義的變數就是全局變數
2.讓所有函數都能訪問到,可以作為函數通信的橋梁
3.一般情況下,為了和普通變數的區別,需要加上g_或gl_前綴
4.全局變數一般放在所有函數的最上面
5.在函數內部修改全局變數,必須要加上global關鍵字,如果不加global只是定義了一個同名的局部變數
函數的多個返回值
Ⅵ Python其實很簡單 第九章 列表與元組(一)
在前面,我們要保存一個數據,需要先定義一個變數,而且一個變數中只能保存一個數據。譬如,語句:a1=1,值「1」就被保存了,但要保存「2」,就還需要再定義一個變數:a2=2......這樣以來,隨著數據的增多,豈不是要定義更多的變數嗎?
可以使用一個新的數據類型,它記錄很多數據,並且將它們按照順序存儲在連續的內存空間中,這便是序列。Python中有5種常用的序列結構,分別是列表、元組、集合、字典和字元串。
9.1列表
語法格式:
listname=[element1,element2,element3,......,elementn]
其中,listname為列表名,element1,element2,element3,......,elementn表示列表中的元素。各個元素的數據類型可以相同,也可以不同,但通常元素的類型都是相同的,含義也是相同的。
如:
list1=[『風』,』馬『,』牛』,1,2,3,』a』,』b』,』c』]就沒有太多的實際用途。
list2=['張三','男',18,']雖然元素的類型不同,但表示了同一個人的信息。
1、訪問列表元素
列表中元素的索引號從0開始標記,訪問列表元素時,可以直接按照索引號讀取。
如:
list2=['張三','男',18,']
print(list2[1]) #輸出列表中索引號為1的元素
輸出結果:男
和字元串一樣,序列都是可以使用切片操作的。
如:
print(list2[:2])
輸出結果:['張三', '男']
print(list2[2:])
輸出結果:[18, ']
2、使用range()函數創建數值列表
格式:range(start, stop [,step]) ;start 指的是計數起始值,默認是 0;stop 指的是計數結束值,但不包括 stop ;step 是步長,默認為 1,不可以為 0 。range() 方法生成一段左閉右開的整數范圍。
可以使用range()函數創建數值列表,如:
list1=list(range(10,20,2))
print(list1)
運行結果:[10, 12, 14, 16, 18]
3、刪除列表
語法格式如下:
del listname
其中,listname為要刪除列表的名稱。
刪除列表與刪除變數的方法是完全一樣的,前面已經介紹過了。
4、遍歷列表
常用的遍歷列表的方法有是利用for語句,舉例如下:
list1=list(range(10))
for item in list1:
print(item,end=' ') # end=』 『表示以空格結束,如果不寫這個參數,相當於默認值end=』 』
輸出結果:0 1 2 3 4 5 6 7 8 9
為了獲取列表元素的索引值,就需要使用enumerate()函數。
list1=list(range(10,20,2))
for index,item in enumerate(list1):
print(index,'-',item,end=' ')
輸出結果:0 - 10 1 - 12 2 - 14 3 - 16 4 - 18
5、追加、修改和刪除列表元素
追加元素
>>> list1=['春','夏','秋']
>>> list1.append('冬')
>>> list1
['春', '夏', '秋', '冬']
還有一種方法,就是使用「+」號將兩個序列連接起來。如:
list1=['春','夏','秋']
list1=list1+['冬']
print(list1)
輸出結果為:['春', '夏', '秋', '冬']
注意,下面的做法是錯誤的:
>>> list1=['春','夏','秋']
>>> list1=list1+'冬'
Traceback (most recent call last):
File " ", line 1, in
list1=list1+'冬'
TypeError: can only concatenate list (not "str") to list
從這個提示可知,列表只能與列表連接,而不能與字元串連接。
修改元素
>>> list1[2]='autumn' #通過索引對元素直接賦值
>>> print(list1)
['春', '夏', 'autumn', '冬']
刪除元素
>>> del list1[2] #通過索引直接刪除元素
>>> print(list1)
['春', '夏', '冬']
6、列表元素排序
在討論列表元素排序時,為了將有序列表變成無序列表,這里用到了shuffle()函數,但它不是Python的內置函數,需要先使用import語句將random模塊包含進來,這樣才能像使用內置函數那樣使用擴展模塊中的函數。
>>> import random #導入random模塊
>>> list1=list(range(10)) #生成列表,元素為0到9的整數。
>>> list1
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> random.shuffle(list1) #用random包中的shuffle()函數將list1中元素次序打亂
>>> list1
[8, 6, 3, 5, 0, 7, 1, 9, 2, 4]
>>> list1.sort() #對list1升序排列
>>> list1
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> random.shuffle(list1) #將list1順序重新打亂
>>> list1
[5, 9, 7, 8, 4, 3, 2, 0, 6, 1]
>>> list1.sort(reverse=True) #對list1降序排列
>>> list1
[9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
方法sort()的語法格式:
listname.sort(key=None,reverse=False)
其中,listname表示要排序的列表;key表示指定一個鍵,如」key=str.lower」表示排序時不區分字母大小寫;reverse為True表示降序排列(為默認值,可省缺),為False表示升序排列。
還有一個函數sorted(),功能與方法sort()相似。格式如下:
sorted(listname,key=None,reverse=False)
7、 利用列表推導式快速生成一個列表
例1:生成指定范圍的數值列表。
>>> import random
>>> list1=[random.randint(0,20) for i in range(10)]
>>> list1
[16, 20, 19, 6, 5, 7, 10, 5, 12, 5] #生成了包含10個值在0到20之間的元素構成的列表。
例2:根據現有列表生成新的列表。
>>> radius=list(range(1,6)) #生成列表 radius保存半徑的值
>>> radius
[1, 2, 3, 4, 5]
>>> s=[round(2*3.14*r,2) for r in radius]
#生成列表s,將計算得到的周長值保存起來,其中round()可以保留指定小數位,格式 round(var, n),var為變數名,n為指定保留小數位。
>>> s
[6.28, 12.56, 18.84, 25.12, 31.4]
例3:從列表中選擇符合條件的元素組成新的列表。
>>> score=[98,65,77,56,82,89] #列表score用來存儲成績
>>> good=[x for x in score if x>=80]
#從列表score中選取>=80的元素存入新列表good中
>>> good
[98, 82, 89]
count()、index()和sum()方法
count()方法
用於統計指定元素在列表中出現的次數。
例:
>>> list1=['a','b','c','d','e','f','c','d','e','a','b','c','d']
>>> num=list1.count('c') #統計列表list1中'c'的個數
>>> num
3
index()方法
用於獲取指定元素在列表中第一次出現的索引值。
>>> list1=['a','b','c','d','e','f','c','d','e','a','b','c','d']
>>> position=list1.index('c')
>>> position
2
sum()方法
用於計算數值列表中全部或指定元素的和。
>>> list1=[1,2,3,4,5]
>>> total=sum(list1) #計算列表list1中全部元素的和
>>> total
15
>>> total=sum(list1,1) #在列表list1全部元素的和後,在加上參數(「1」)的值
>>> total
16
>>> total=sum(list1[:2]) #計算切片list1[:2]中各元素的和
>>> total
3
二維列表
格式:listname[下標1][下標2]
其中,listname表示列表的名稱,下標1表示列表中的行號,下標2表示列表中的列號。對於n行m列的二維列表,第一個元素的行號和列號都是0,最後一個元素的行號和列號都是n-1。如下所示:
list[0][0] list[0][1] list[0][2] ............ list[0][m-1]
list[1][0] list[1][1] list[1][2] ............ list[1][m-1]
......
......
list[n-1][0] list[n-1][1] list[n-1][2] ............ list[n-1][m-1]
通俗地講,如果一個列表中的元素本身就是一個列表,則這個列表就是一個二維列表。
如:
>>> list1=['a1','b1','c1','d1']
>>> list2=['a2','b2','c2','d2']
>>> list3=['a3','b3','c3','d3']
>>> listtwo=[list1,list2,list3]
>>> listtwo
[['a1', 'b1', 'c1', 'd1'], ['a2', 'b2', 'c2', 'd2'], ['a3', 'b3', 'c3', 'd3']]
如果要查看二維列表listtwo按照行、列的排列,可以運行如下代碼:
for i in range(3):
for j in range(4):
print(listtwo[i][j],end=' ')
print()
運行結果:
a1 b1 c1 d1
a2 b2 c2 d2
a3 b3 c3 d3
如果要讀取二維列表中的某一行,可以使用如下方法:
>>> listtwo[2] #讀取第3行的元素(注意索引號都是從0開始的)
['a3', 'b3', 'c3', 'd3']
如果要讀取某一個元素的值,可以使用如下方法:
>>> listtwo[2][2] #讀取第3行第3列的元素
'c3'
Ⅶ Python中的列表
列表(list)是Python中一個非常重要的類型,用於管理一組數據,列表的形式如下所示
country = ['China', 'Germany', 'Russia', 'America']
1)數據包含在引號中,Python中單引號和雙引號具有相同的作用
2)使用逗號分隔數據,整個列表包含在一個中括弧中
3)適用賦值操作符將一個列表賦值給一個變數名如上述例子中的「country」, Python的變數名不需要聲明類型
country = []
列表不僅可以存放字元串這樣的數據,還可以存放混合類型的數據,例如在列表中存儲列表
除了列表外還可以存儲字典和元組,字典和元組另作介紹
列表可以像數組那樣通過下標獲取列表中的數據,數據類型---字元串
列表可以適用冒號「:」操作符選取列表中的一部分數據,選取出的數據成為切片,實際上是字列表,但這些數據需要是連續的。
此外數據可以正向取如示例中的「0 : 2」得到列表['China', 'Germany'], 也可以反向取如「-2:-1」
需要注意的是即使切片只取一個數據得到的也是一個列表,而不是一個字元串,與使用索引得到的數據是不同的
添加數據可以使用 insert() 和 append() 兩種方法,如下所示:
insert() 第一個參數確定插入的位置,在這個位置之後插入需要插入的數據, append() 將數據添加到列表的尾部
從列表中找出某個值第一個匹配項的索引位置
只能查找第一層數據,如果差列表中的列表,需要將列表全部輸入。函數中的start和stop用於確定搜索范圍
移除列表中的一個元素(默認最後一個元素),並且返回該元素的值
移除列表中某個值的第一個匹配項
反向列表中元素
對原列表進行排序