'''''' ''' 1 python的定義 是一門弱類型的解釋性的高級編程語言 這裡的高級是相對低級(例如:彙編語言等) 高級編程語言和低級編程語言的區別 1、前者更接近於人的理解--字母組成的語法 2、後者更接近於計算器的理解--位元組碼、二進位 2 python的特點 人生苦短,我用python... ...
'''''' ''' 1 python的定義 是一門弱類型的解釋性的高級編程語言 這裡的高級是相對低級(例如:彙編語言等) 高級編程語言和低級編程語言的區別 1、前者更接近於人的理解--字母組成的語法 2、後者更接近於計算器的理解--位元組碼、二進位 2 python的特點 人生苦短,我用python 簡潔 3 為什麼學習python 愛好,人工智慧,機器學習,大數據 4 python第一個程式 print('hello world') 方式1:在cmd中輸入python後,在交互命令行,輸入上述語句,enter 方式2:在本地d盤新建一個hello.py的文件,將上述語句複製到.py文件中,保存後 在cmd中,進入到d盤, 執行命令 python hello.py 方式3:將上述語句寫入pycharm後,run 5 變數的概念 變數是程式運行過程中產生的中間值--temp(暫存屬性,開闢一個記憶體空間,用於保存值) 1、記憶體空間的名字就是變數的名字 2、記憶體空間保存的值就是變數的值 比如: a=10 變數名字就是a 變數的值是10 6 變數的命名規則: 1、組成:數字、字母、下劃線組成 2、開頭:不能是數字開頭 3、關鍵字:不能是關鍵字,比如:list 4、長度:不要太長 5、中文:不要是中文 6、有意義:要有意思(一看名字,就知道變數大概表示的意思) 7、大小寫:嚴格區分大小寫 8、寫法:推薦下劃線或者駝峰法命名 下劃線:hello_world(單詞之間,下劃線分隔開) 駝峰法:helloWorld (首字母不大寫,第二個單詞開始,首字母大寫) 7 變數的數據類型 1 int 整數 + - * / // bit_length() 2 str 字元串 1、表示方式 ' " \''' \""" 註意點:這裡的\ 表示轉義 1 單引號'' 2 雙引號"" 3 三個單引號 ''' ''' 4 三個雙引號 """ """ 2、* 重覆 3、+ 拼接 4、%s 格式化 5、索引和切片 s1[start:end:step] 左閉右開 1 start 起始索引號-下標 2 end 結束索引號-下標 (取不到) 3 start 步長(不寫,預設是1) 6、常見內置方法 1 upper() 轉換成大寫字母 2 strip() 去掉字元串兩端的空白 strip('ab') 去掉字元串兩端的'ab' 3 replace(old,new,count) 參數3 count表示從左到右替換的次數 參數3不寫,預設是全部替換 4 split() 把字元串拆分成幾個子字元串,每個子字元串作為列表的元素,返回的是列表 預設分隔符是空格 split('_') 分隔符是下劃線 5 '_'.join() 把參數iterable中的字元串通過連接符'_'拼接成字元串 寫法: '連接符'.join(iterable) 註意點: 1 iterable中的元素必須是str,而不能是int 2 join不是字元串的內置方法 6 startswith() 寫法:s1.startwith('a') 作用:判斷字元串是否以字母'a'開頭 7 find index count 寫法:s1.find('a') 作用:從字元串s1中查找字元‘a’,返回索引號;如果找不到,就返回-1 --更健壯 推薦 寫法:s1.index('a') 作用:從字元串s1中查找字元‘a’,返回索引號;如果找不到,就報錯 寫法:s1.count('a') 作用:從字元串s1中統計字元'a'出現的次數,返回出現的次數int 如果是0次,代表沒有找到(也有查找的功能) 8 isdigit() 寫法:s1.isdigit() 作用:判斷字元串是否是數字形式的,是的話,返回True 9 len() 寫法:len(s1) 作用:返回字元串的長度 7、字元串是iterable for i in s1: 迴圈體(break continue) else: pass 8、字元串的編碼方式 1 ascii 8位 1個位元組 2 gbk 國標碼 gb2312 16位 2個位元組 3 unicode 萬國碼 32位 4個位元組 4 utf-8 可變的unicode 1 英文字元 8位 1個位元組 2 歐洲字元 16位 2個位元組(德文、法文、西班牙文等字元) 3 中文字元 24位 3個位元組 字元串編碼後變成位元組bytes 編碼-加密-壓縮 位元組解碼後變成字元串 解碼-解密-解壓 bytes.decode() #解碼 3、bool 布爾類型 取值:True False 作用:用於判斷的 類型轉換: False:0或者空('' [] () {} set() None) 空字元串、空列表、空元組、空字典、空集合、空None 註意:空格、\r \n \t都是True True:除了上面的,其他都是True 註意點:類型轉換False可以直接用於判斷 備註: 例子1 content1 = input('請輸入你的名字:') #輸入的是字元串 if content1: #判斷空 如果不輸入內容,直接回車,就提示-你沒有名字 註意點:和下麵行的結果不一樣 # if content1 == '': #如果不輸入內容,直接回車,就列印-你的名字是 print('你的名字是 ',content1) else: #如果你什麼都沒有輸入,這個content1就是空字元串 print('你沒有名字') 例子2 li1 = [1,2,3] if li1: #這裡就是在判斷列表是否為空, 和下麵行等效 # if li1 == []: print(li1) else: # print('空列表') 4、列表 list 表示:[],元素之間是逗號隔開 概念:列表是一個容器,可以存放任意數據類型 和其他開發語言的數組array類似 特點: 1、列表是可變的 2、列表由索引和切片功能 常見操作: 1 增 1 append(元素值) 在列表最後面追加元素 2 insert(i,元素值) 在列表指定位置前插入元素 3 extend(iterable) 把iterable中的元素依次添加到原列表 2 刪 1 pop() 參數不寫,預設是刪除最後一個元素 參數也可以指定索引號,來刪除 2 remove 刪除指定的元素值 3 del 切片或者單個刪除 4 clear 清空元素 3 改 1 按照索引-下標修改 切片修改 單個索引號修改 4 查 1、單個索引號取值 2、for迴圈遍歷 01列表-增加元素小結 1 append是末尾追加新元素--最常用 2 insert是指定位置前插入新元素 3 extend是將iterable中元素依次添加到原列表 02列表-刪除元素小結 1 pop 不帶參數,預設刪除列表最後一個元素,並且獲取到被刪除的最後一個元素 指定參數,刪除指定位置-索引號的元素,並且獲取到被刪除的指定位置的元素 2 remove 參數:元素值(不是位置) 作用:刪除指定元素值 3 del 1 參數:單個位置-索引號 寫法:del 列表(位置) 作用:刪除單個位置的元素 2、參數:切片 寫法:del 列表(切片) 作用:切片刪除多個位置的元素 3、參數:列表名 寫法:del 列表名 作用:刪除整個列表,回收記憶體空間(和清空clear是不同的) 4、參數:字典的key 寫法:del 字典名[key] 作用:刪除字典中指定key對應的鍵值對 綜上,del的作用 1、可以刪除單個位置的元素 2、可以切片刪除多個元素 3、可以刪除整個列表,回收記憶體空間 4、不僅是列表,也適用於字典 4 clear 參數:為空 寫法:li1.clear() 作用:清空列表的元素,變成空列表 清空-列表的記憶體空間沒有被回收(和del li1不一樣) 03列表-修改元素小結 1 單個位置修改--單個元素修改 寫法:li3[1] = 'james' 作用:指定位置-索引號進行列表單個元素的修改 2、切片多個元素修改 1 2個元素改成1個元素 正確寫法:li3[1:3] = ['james'] 錯誤寫法:li3[1:3] = 'james' 註意點 2 2個元素改成2個元素 寫法:li3[1:3] = ['james','kevin'] 3 2個元素改成3個元素 寫法:li3[1:3] = ['james','kevin','lucy'] 04列表-查詢元素小結 1 單個查詢-單個取值-按照單個位置-索引號-下標 2 多個查詢-多個取值-按照切片 3 全部查詢-全部取值-for迴圈遍歷 5、其他常見操作 1 count() 計數 計算某個元素在列表出現的次數 2 index() 查找 返回某個元素在列表中的位置-索引號-下標 3 sort() 排序 把列表的元素進行排序,預設升序,列表本身修改了 4 reverse()反轉 把列表的元素反轉,列表本身修改了 6、列表在迴圈遍歷的過程中,不能刪除元素,因為涉及到元素的移動 解決辦法: 把要刪除的元素,添加到新的列表中,迴圈新列表,刪除老列表 7、深淺拷貝和賦值 1、= 賦值,兩個變數指向同一個記憶體地址,不同的變數只是同一個記憶體地址的不同別名 2、淺拷貝,只拷貝第一層(第二層及以上還是指向同一個記憶體空間,沒有實現拷貝) li1.copy() li1[:] 檢驗是否是一個記憶體空間的辦法:看變數的id值 3、深拷貝,不僅拷貝第一層,第二層及以上都拷貝 li1.deepcopy() 擴展:在其他的編程語言(比如:java),叫做克隆,也分為深淺克隆 淺拷貝和深拷貝的類比 1、淺拷貝是第一層記憶體空間分開,第二層及以上記憶體空間是同一個 --第一層獨立,第二層及以上是一變都變 第一層就是家庭夫妻財務AA 第二層就是家庭夫妻設立的共同賬戶 2、深拷貝是第一層記憶體空間分開,第二層及以上記憶體空間也分開--每層完全獨立 類比:家庭夫妻財務完全AA,沒有設立共同賬戶 8、列表推導式 寫法 [結果 for迴圈 if判斷] 例子: li7 = [1,2,3] #需求:將列表中的奇數,變成其平方數 li8 = [i*i for i in li7 if i%2 == 1 ] print(li8) #[1, 9] '''