
Python字典,函數(shù),全局變量代碼解析
字典
dict1 = {'name':'han','age':18,'class':'first'}
print(dict1.keys()) #打印所有的key值
print(dict1.values()) #打印所有的values值
print("dict1['name']:",dict1['name']) #打印name相對(duì)應(yīng)的value值
print(dict1.get('name')) #通過字典的get方法得到name相對(duì)應(yīng)的value值
dict1['age']=28 #字典的修改相當(dāng)于重新賦值?。。?br />
dict1['address']='beijing' #字典的增加是:dict[key] = value 這樣的形式
del dict1['name'] #刪除字典中的一個(gè)元素
dict1.clear() #字典的清空,返回一個(gè)空字典
# del dict1 #刪除字典,字典就完全刪除了
字典用法注意:
1、鍵是不允許相同的,如果相同,后面的會(huì)覆蓋前面的
2、鍵是不可變的,所以只能用數(shù)字、字符串、元組來擔(dān)當(dāng)
dict2 = {(1,2):5,"元組":(4,5)} #字典里的元素只能用不可變的數(shù)據(jù)類型?。?!
print(dict2)
print(dict2['元組'])
print(dict2[(1,2)])
for i in dict2.keys(): #取出的數(shù)值更干凈?。?!謹(jǐn)記老師教導(dǎo)
print("字典中的key值為:",i)
for j in dict2.values():
print("字典中的values值為:",j)
函數(shù)
1、函數(shù)的定義
函數(shù)是實(shí)現(xiàn)特定功能而封裝起來的一組語句塊,可以被用戶調(diào)用
2、函數(shù)的分類
自定義函數(shù);預(yù)定義函數(shù)(系統(tǒng)自帶,lib自帶)
3、使用函數(shù)的好處
降低編程難度、將大問題分解為若干小問題、可以多次調(diào)用
4、函數(shù)語法
定義
def函數(shù)名字(參數(shù)):
函數(shù)體
return語句#不帶表達(dá)式的return相當(dāng)于返回none
調(diào)用
函數(shù)名字
以下是函數(shù)的幾種:
#定義函數(shù),函數(shù)名最好以_分割
def print_str(str):
print(str)
return
# 調(diào)用函數(shù)
print_str("調(diào)用一下")
# 函數(shù)傳遞
#所有參數(shù)在python里都是按引用傳遞
#一句話:要變都變!??!
def charge_me(mylist):
mylist.append([1,2,3,4])
print("函數(shù)內(nèi)取值:",mylist)
return
mylist = [10,20,30]
charge_me(mylist)
print("函數(shù)外取值:",mylist) #函數(shù)外和函數(shù)內(nèi)打印是相同的!??!
#函數(shù)的賦值引用
def print_info(name,age=3):
print("name",name)
print("age",age)
return
# print_info(name="xiao",age=18)
print_info(age=50,name="xiao") #python中顛倒是可以的?。?!
print_info(name='haha')
#函數(shù)的不定長參數(shù)
def p_info(arg1,*vartuple):
print("輸出:",arg1)
for var in vartuple:
print(var)
return
p_info(10)
p_info(70,60,50,40,30)
匿名函數(shù)lambda,了解即可
# 1、lambda只是一個(gè)表達(dá)式,而不是一個(gè)代碼塊,函數(shù)體比def簡單很多。僅僅能在lambda表達(dá)式中封裝有限的邏輯
# 2、lambda[arg1[,arg2,...argn]]:expression
sum1 = lambda arg1,arg2:arg1+arg2
print("相加后的值為:",sum1(10,20))
# return語句
def sum2(arg1,arg2):
total = arg1+arg2
print("函數(shù)內(nèi):",total)
return total #把total去掉之后返回none
abc = sum2(10,40)
print("函數(shù)外:",abc)
#全局變量和局部變量
#全局變量比較容易出問題,能不用就不用
total = 0
def sum3(a,b):
total = a+b
print("函數(shù)內(nèi)(局部變量)的值為:",total)
return total
# total = sum3(10,400)
sum3(20,70)
print("函數(shù)外(全局變量)的值為:",total)
count = 1
def do_st():
global count #全局變量:global
for i in (3,4,5): #循環(huán)三次
count += 1
# print(count)
do_st()
print(count)
# 思路:當(dāng)count=1時(shí)進(jìn)入循環(huán)+1并賦值給count
# 在for循環(huán)三次后為3+1=4
# count是全局變量,最后打印出的結(jié)果為4
小練習(xí)
# 不能創(chuàng)建字典的語句是C (字典中的元素不能以列表作為key)
# A、dict1 = {}
# B、dict2 = { 3 : 5 }
# C、dict3 = {[1,2,3]: “uestc”}
# D、dict4 = {(1,2,3): “uestc”}
#以下代碼輸出什么?輸出的是6
# 思路:原始key的值為1,
# copy給另一個(gè)字典值為1,
# 重新賦值原來的字典值為5,
# 所以相加等于6
dict1={'1':1,'2':2}
theCopy=dict1.copy()
dict1['1']=5
sum=dict1['1']+theCopy['1']
print(sum)
# 合并生成新的字典
dict1 = {3:"c", 4:"d"}
dict2 = {1:"a", 2:"b"}
dict2.update(dict1) #更新添加dict1進(jìn)dict2
print(dict2)
# 標(biāo)準(zhǔn)日期輸出
a = "20170303"
b = a[:4]
c = a[4:6] #構(gòu)思:通過列表分割的方式實(shí)現(xiàn)
d = a[6:]
print("格式化后輸出的日期是:%s年%s月%s日"%(b,c,d))
無return函數(shù),返回什么?
答:在函數(shù)中無return函數(shù),返回none
如何在一個(gè)function里面設(shè)置一個(gè)全局的變量?
答:在函數(shù)體內(nèi)定義一個(gè)全局的函數(shù)global
#隨機(jī)生成驗(yàn)證碼的兩種方式:
import random
list1=[]
for i in range(65,91):
list1.append(chr(i)) #通過for循環(huán)遍歷asii追加到空列表中
for j in range(97,123):
list1.append(chr(j))
for k in range(48,58):
list1.append(chr(k))
ma = random.sample(list1,6)
print(ma) #獲取到的為列表
ma = ''.join(ma) #將列表轉(zhuǎn)化為字符串
print(ma)
import random,string
str1 = "0123456789"
str2 = string.ascii_letters
str3 = str1+str2
ma1 = random.sample(str3,6)
ma1 = ''.join(ma1)
print(ma1) #通過引入string模塊和random模塊使用現(xiàn)有的方法
總結(jié)
以上就是本文關(guān)于Python字典,函數(shù),全局變量代碼解析的全部內(nèi)容,希望對(duì)大家有所幫助
數(shù)據(jù)分析咨詢請掃描二維碼
若不方便掃碼,搜微信號(hào):CDAshujufenxi
SQL Server 中 CONVERT 函數(shù)的日期轉(zhuǎn)換:從基礎(chǔ)用法到實(shí)戰(zhàn)優(yōu)化 在 SQL Server 的數(shù)據(jù)處理中,日期格式轉(zhuǎn)換是高頻需求 —— 無論 ...
2025-09-18MySQL 大表拆分與關(guān)聯(lián)查詢效率:打破 “拆分必慢” 的認(rèn)知誤區(qū) 在 MySQL 數(shù)據(jù)庫管理中,“大表” 始終是性能優(yōu)化繞不開的話題。 ...
2025-09-18CDA 數(shù)據(jù)分析師:表結(jié)構(gòu)數(shù)據(jù) “獲取 - 加工 - 使用” 全流程的賦能者 表結(jié)構(gòu)數(shù)據(jù)(如數(shù)據(jù)庫表、Excel 表、CSV 文件)是企業(yè)數(shù)字 ...
2025-09-18DSGE 模型中的 Et:理性預(yù)期算子的內(nèi)涵、作用與應(yīng)用解析 動(dòng)態(tài)隨機(jī)一般均衡(Dynamic Stochastic General Equilibrium, DSGE)模 ...
2025-09-17Python 提取 TIF 中地名的完整指南 一、先明確:TIF 中的地名有哪兩種存在形式? 在開始提取前,需先判斷 TIF 文件的類型 —— ...
2025-09-17CDA 數(shù)據(jù)分析師:解鎖表結(jié)構(gòu)數(shù)據(jù)特征價(jià)值的專業(yè)核心 表結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 規(guī)范存儲(chǔ)的結(jié)構(gòu)化數(shù)據(jù),如數(shù)據(jù)庫表、Excel 表、 ...
2025-09-17Excel 導(dǎo)入數(shù)據(jù)含缺失值?詳解 dropna 函數(shù)的功能與實(shí)戰(zhàn)應(yīng)用 在用 Python(如 pandas 庫)處理 Excel 數(shù)據(jù)時(shí),“缺失值” 是高頻 ...
2025-09-16深入解析卡方檢驗(yàn)與 t 檢驗(yàn):差異、適用場景與實(shí)踐應(yīng)用 在數(shù)據(jù)分析與統(tǒng)計(jì)學(xué)領(lǐng)域,假設(shè)檢驗(yàn)是驗(yàn)證研究假設(shè)、判斷數(shù)據(jù)差異是否 “ ...
2025-09-16CDA 數(shù)據(jù)分析師:掌控表格結(jié)構(gòu)數(shù)據(jù)全功能周期的專業(yè)操盤手 表格結(jié)構(gòu)數(shù)據(jù)(以 “行 - 列” 存儲(chǔ)的結(jié)構(gòu)化數(shù)據(jù),如 Excel 表、數(shù)據(jù) ...
2025-09-16MySQL 執(zhí)行計(jì)劃中 rows 數(shù)量的準(zhǔn)確性解析:原理、影響因素與優(yōu)化 在 MySQL SQL 調(diào)優(yōu)中,EXPLAIN執(zhí)行計(jì)劃是核心工具,而其中的row ...
2025-09-15解析 Python 中 Response 對(duì)象的 text 與 content:區(qū)別、場景與實(shí)踐指南 在 Python 進(jìn)行 HTTP 網(wǎng)絡(luò)請求開發(fā)時(shí)(如使用requests ...
2025-09-15CDA 數(shù)據(jù)分析師:激活表格結(jié)構(gòu)數(shù)據(jù)價(jià)值的核心操盤手 表格結(jié)構(gòu)數(shù)據(jù)(如 Excel 表格、數(shù)據(jù)庫表)是企業(yè)最基礎(chǔ)、最核心的數(shù)據(jù)形態(tài) ...
2025-09-15Python HTTP 請求工具對(duì)比:urllib.request 與 requests 的核心差異與選擇指南 在 Python 處理 HTTP 請求(如接口調(diào)用、數(shù)據(jù)爬取 ...
2025-09-12解決 pd.read_csv 讀取長浮點(diǎn)數(shù)據(jù)的科學(xué)計(jì)數(shù)法問題 為幫助 Python 數(shù)據(jù)從業(yè)者解決pd.read_csv讀取長浮點(diǎn)數(shù)據(jù)時(shí)的科學(xué)計(jì)數(shù)法問題 ...
2025-09-12CDA 數(shù)據(jù)分析師:業(yè)務(wù)數(shù)據(jù)分析步驟的落地者與價(jià)值優(yōu)化者 業(yè)務(wù)數(shù)據(jù)分析是企業(yè)解決日常運(yùn)營問題、提升執(zhí)行效率的核心手段,其價(jià)值 ...
2025-09-12用 SQL 驗(yàn)證業(yè)務(wù)邏輯:從規(guī)則拆解到數(shù)據(jù)把關(guān)的實(shí)戰(zhàn)指南 在業(yè)務(wù)系統(tǒng)落地過程中,“業(yè)務(wù)邏輯” 是連接 “需求設(shè)計(jì)” 與 “用戶體驗(yàn) ...
2025-09-11塔吉特百貨孕婦營銷案例:數(shù)據(jù)驅(qū)動(dòng)下的精準(zhǔn)零售革命與啟示 在零售行業(yè) “流量紅利見頂” 的當(dāng)下,精準(zhǔn)營銷成為企業(yè)突圍的核心方 ...
2025-09-11CDA 數(shù)據(jù)分析師與戰(zhàn)略 / 業(yè)務(wù)數(shù)據(jù)分析:概念辨析與協(xié)同價(jià)值 在數(shù)據(jù)驅(qū)動(dòng)決策的體系中,“戰(zhàn)略數(shù)據(jù)分析”“業(yè)務(wù)數(shù)據(jù)分析” 是企業(yè) ...
2025-09-11Excel 數(shù)據(jù)聚類分析:從操作實(shí)踐到業(yè)務(wù)價(jià)值挖掘 在數(shù)據(jù)分析場景中,聚類分析作為 “無監(jiān)督分組” 的核心工具,能從雜亂數(shù)據(jù)中挖 ...
2025-09-10統(tǒng)計(jì)模型的核心目的:從數(shù)據(jù)解讀到?jīng)Q策支撐的價(jià)值導(dǎo)向 統(tǒng)計(jì)模型作為數(shù)據(jù)分析的核心工具,并非簡單的 “公式堆砌”,而是圍繞特定 ...
2025-09-10