­

python之路,Python基礎篇2(

  • 2020 年 1 月 10 日
  • 筆記
一、.pyc是個什麼鬼:  	pyc文件其實是PyCodeObject的一種持久化保存方式。    二、數據類型    1、數字:  	2 是一個整數的例子。  	長整數 不過是大一些的整數。  	3.23和52.3E-4是浮點數的例子。E標記表示10的冪。在這裡,52.3E-4表示52.3 * 10-4。  	(-5+4j)和(2.3-4.6j)是複數的例子,其中-5,4為實數,j為虛數,數學中表示複數是什麼?    int(整型)    在32位機器上,整數的位數為32位,取值範圍為-2**31~2**31-1,即-2147483648~2147483647    在64位系統上,整數的位數為64位,取值範圍為-2**63~2**63-1,即-9223372036854775808~9223372036854775807  long(長整型)    跟C語言不同,Python的長整數沒有指定位寬,即:Python沒有限制長整數數值的大小,但實際上由於機器記憶體有限,我們使用的長整數數值不可能無限大。    注意,自從Python2.2起,如果整數發生溢出,Python會自動將整數數據轉換為長整數,所以如今在長整數數據後面不加字母L也不會導致嚴重後果了。  float(浮點型)    浮點數用來處理實數,即帶有小數的數字。類似於C語言中的double類型,佔8個位元組(64位),其中52位表示底,11位表示指數,剩下的一位表示符號。  complex(複數)    複數由實數部分和虛數部分組成,一般形式為x+yj,其中的x是複數的實數部分,y是複數的虛數部分,這裡的x和y都是實數。  註:Python中存在小數字池:-5 ~ 257      #複數,生產環境用得比較少。  python 2.7 有整型和長整型之分:    	>>> (2) -1  	1  	>>> (2**31) -1  	2147483647L  	>>>    	>>> type( (2**30) -1)  	<type 'int'>  	>>> type( (2**31) -1)  	<type 'long'>  	>>>    python 3.x 沒有整型和長整型之分:    	>>> type( (2**30) -1)  	<class 'int'>  	>>> type( (2**31) -1)  	<class 'int'>  	>>>    2、布爾值    	真或假  	1 或 0    	>>> 1 is True  	False  	>>> 0 is False  	False  	>>> 0 is True  	False    3、字元串    	"hello world"    	萬惡的字元串拼接:  	python中的字元串在C語言中體現為是一個字元數組,每次創建字元串時候需要在記憶體中開闢一塊連續的空,並且一旦需要修改字元串的話,就需要再次開闢空間,萬惡的+號每出現一次就會在內從中重新開闢一塊空間。    	>>> name = 'luchuan'  	>>> print("my name is " + name + " and you ? ")  	my name is luchuan and you ?  	>>>    #這等於三塊記憶體空間    字元串格式化輸出    	name = "luchuan"  	print "i am %s " % name    #輸出: i am luchuan    PS: 字元串是 %s;整數 %d;浮點數%f    字元串常用功能:  	移除空白  	分割  	長度  	索引  	切片    1)strip 移除空白  	username = input("user:")  	if username.strip() == 'alex':  		print("welcome")    2)split 分割  	name = "alex,jack,rain"  	name2 = name.split(",")  	print(name2)    3)join 字元串合起來  	name = "alex,jack,rain"  	name2 = name.split(",")  	print("|".join(name2))    4)『』 in name 判斷有沒有空格  	name="alex li"  	print('' in name)    5)capitalize 首字母大寫  	name="alex li"  	print(name.capitalize())    6)format 格式化  	msg = "Hello, {name}, it's been a long {age} since last time sopke..."  	msg2 = msg.format(name='xiaoming',age=33)  	print(msg2)    	msg2 = "haha{0}, dddd{1}"  	print(msg2.format('Alex',33))    7)center 居中  	name="alex li"  	print(name.center(40,'-'))    8)find 查找  	name = 'alex3sdf'  	print(name.find('a'))    9)isdigit是否是數字  	age = input("your age:")  	if age.isdigit():  		age = int(age)  		print(age)  	else:  		print("invalid data type")    10)isalnum 是否只包含字母數字字元  	name = 'alex3sdf'  	print(name.isalnum())    11)endswith 什麼時候結尾  	name = 'alex3sdf'  	print(name.endswith('df'))    12)startswith 什麼時候開始  	name = 'alex3sdf'  	print(name.startswith('df'))    13)upper 大寫  	name = 'alex3sdf'  	print(name.upper())    14)lower 小寫  	name = 'alex3sdf'  	print(name.upper().lower())  15)len 長度  	print(len(name))    4、列表  python包含6種內建的序列:列表、元組、字元串、Unicode字元串、buffer對象和xrange對象。  列表只有在Python中叫列表,在其他語言中叫數組。  索引是訪問單個元素,分片操作是訪問一定範圍內的元素    創建列表:    	name_list = ['alex', 'seven', 'eric']  	或  	name_list = list(['alex', 'seven', 'eric'])    基本操作:    索引  切片  追加  刪除  長度  循環  包含      name = ['Alex', 'jack', 'Rain', 'Eric', 'Monica', 'Fiona']  >>> name[:]  ['Alex', 'jack', 'Rain', 'Eric', 'Monica', 'Fiona']      索引  >>> name[2]  'Rain'    切片  >>> name[2:4]  ['Rain', 'Eric']  >>> name[2:4][0]  'Rain'  >>> name[2:4][0][1:2]  'a'    修改:  >>> name[1]="xiaoming"  >>> name  ['Alex', 'xiaoming', 'Rain', 'Eric', 'Monica', 'Fiona']    插入:  >>> name.insert(2,'daming')  >>> name  ['Alex', 'xiaoming', 'daming', 'Rain', 'Eric', 'Monica', 'Fiona']    追加:  >>> name.append('alex')  >>> name  ['Alex', 'xiaoming', 'daming', 'Rain', 'Eric', 'Monica', 'Fiona', 'alex']    刪除:  >>> name.remove("daming")  >>> name  ['Alex', 'xiaoming', 'Rain', 'Eric', 'Monica', 'Fiona', 'alex']    練習:  往中間插入兩個臨組成員的名字  取出第3-8的人列表  刪除第9個人  把剛才加入的那2個其他組的人一次性刪除  把組長的名字加上組長備註  要求你隔一個人列印一個人    >>> name = ['Alex', 'xiaoming', 'Rain', 'Eric', 'Monica', 'Fiona']    >>> name.insert(-1,"xiaochuan")  >>> name.insert(5,"dachuan")    >>> name[3:8]  ['Eric', 'Monica', 'dachuan', 'xiaochuan', 'Fiona']    >>> name.remove("Fiona")  >>> name  ['Alex', 'xiaoming', 'Rain', 'Eric', 'Monica', 'dachuan', 'Fiona']    >>> del name[4:6]    >>> print(name[::2])    長度:  >>> len(name)  7  >>> name  ['Alex', 'xiaoming', 'Rain', 'Eric', 'Monica', 'Fiona', 'alex']    5、元組(不可變列表)  	創建元組:    	ages = (11, 22, 33, 44, 55)  	或  	ages = tuple((11, 22, 33, 44, 55))    6、字典(無序)  	創建字典:  	person = {"name": "mr.wu", 'age': 18}  	或  	person = dict({"name": "mr.wu", 'age': 18})    常用操作:    索引  新增  刪除  鍵、值、鍵值對  循環  長度    為什麼要有字典呢?是因為序列的不足。  字典:  	1、查看  	2、修改:  	3、添加:  	4、刪除:  	5、獲取:  	6、update更新:  	7、items:  	8、values:  	9、keys:  	10、has_key:  	11、setdefault:  	12、fromkeys:  	13、popitem:    id_db = {      371471199306143632:{          'name':"Alex Li",          'age':22,          'addr':'ShanDong'      },      22043549306143632:{          'name':"ShanPao",          'age':24,          'addr':'DongBei'      }  }    查看:  print(id_db[22043549306143632])    修改:  print(id_db[22043549306143632])  id_db[22043549306143632]['name']="xiaoming"  print(id_db[22043549306143632])    添加:  print(id_db[22043549306143632])  id_db[22043549306143632]['name']="xiaoming"  id_db[22043549306143632]['qq_of_wife']=38232354  print(id_db[22043549306143632])    刪除:  print(id_db[22043549306143632])  id_db[22043549306143632]['name']="xiaoming"  id_db[22043549306143632]['qq_of_wife']=38232354  del id_db[22043549306143632]['addr']  print(id_db[22043549306143632])    print(id_db[22043549306143632])  id_db[22043549306143632]['name']="xiaoming"  id_db[22043549306143632]['qq_of_wife']=38232354  id_db[22043549306143632].pop("addr")  print(id_db[22043549306143632])    獲取:  v = id_db.get(22043549306143632)  print(v)    	如果沒有這個值,返回none:  	v = id_db.get(22343549306143632)  	print(v)  	None    	這樣取值會報錯:  	v = id_db[22343549306143632]  	print(v)      update更新:  id_db = {      371471199306143632:{          'name':"Alex Li",          'age':22,          'addr':'ShanDong'      },      22043549306143632:{          'name':"ShanPao",          'age':24,          'addr':'DongBei'      }  }    dic2 = {      'name':'dssfdsfsf',      220435493061436532: {          'name':"DaShanPao",          'age':24,          'addr':'DongBei'      }  }    id_db.update(dic2)  print(id_db)    items:  把字典變成列表,數據量大得情況下,盡量不要使用。  print(id_db)  print(id_db.items())    values:  列印字典里所有的values  print(id_db)  #print(id_db.items())  print(id_db.values())    keys:  列印字典里所有的keys:  print(id_db.keys())    has_key:  id_db.has_key(371471199306143632) #only in 2.x  371471199306143632 in id_db # equals to above has key(x)    setdefault:  如果有那個值,就取出,沒有就在後面賦值:  print(id_db.setdefault(371471199306143632),"hahha")  print(id_db)    fromkeys:這是個坑,有問題再問。  print(id_db.fromkeys([1,2,34,4,5,6],'ddd'))    popitem:隨機刪除一個key,不要使用:  print(id_db.popitem())  print(id_db)    循環一個字典:  #for k,v in id.items(): #效率低,因為要有一個dict to list 的轉換過程  #	print(k,v)    for key in id_db:  	print(key,id_db[key])    三、數據運算    	電腦中能表示的最小單位,是一個二進位位。  	電腦中能存儲的最小單位,是一個二進位位(bit)。  	8bit = byte(位元組)  	1024byte = 1kbyte  	1024kbyte = 1mbyte  	1024mb = 1gb  	1024gb = 1T    算數運算:  比較運算:  賦值運算:  邏輯運算:  成員運算:  身份運算:  位運算:
四、set集合應用    set集合應用:set集合在爬蟲和CMBD中都有用到。  set集合:無序、不重複、可嵌套  li = []  list((11,22,33,4))  # list__init__,內部執行for循環(11,22,33,4) [11,22,33,4]    #創建集合  # s1 = {11,22}  # s2 = set()  #空集合  # s3 = set([11,22,33,4])    ## 操作集合  # s = set()  # print(s)  # s.add(123)  # s.add(123)  # s.add(123)  # print(s)  # s.clear()  # print(s)  # s1 = {11,22,33}  # s2 = {22,33,44}  # s3 = s1.difference(s2)  # A中存在,B中不存在  # s3 = s2.difference(s1)  # s3 = s1.symmetric_difference(s2)  # print(s1)  # print(s2)  # print(s3)  # s1.difference_update(s2)  # s1.symmetric_difference_update(s2)  # print(s1)  # s1 = {11,22,33}  # s2 = {22,33,44}  # s3 = s1.union(s2)  # print(s3)  # s3 = s1.intersection(s2)  # s1.intersection_update(s2)  # print(s3)    刪除:    s1 = {11,22,33}  # s1.discard(1111)  # s1.remove(11111)  s1.pop()  print(s1)  discard 移除某個元素,如果沒有那個元素,不報錯  remove 移除某個元素,如果沒有那個元素,報錯  pop 隨機移除元素,pop內部不能加參數    但凡有帶雙下劃線得都是有特殊意義得:  # li = [11,22,33] # list __init__  # li()            # list __call__  # li[0]           # list __getitem__  # li[0] = 123     # list __setitem__  # def li[1]       # list __delitem__    set集合練習:  尋找差異:  new_dict = {      "#1": 4,      "#2": 4,      "#3": 2,  }    old_dict = {  	"#1":8,  	"#2":4,  	"#4":2,  }    # old_kyes = old_dict.keys()  # old_set = set(old_kyes)  new_set = set(new_dict.keys())  old_set = set(old_dict.keys())  remove_set = old_set.difference(new_set)  add_set = new_set.difference(old_set)  update_set = old_set.intersection(new_set)      # 資料庫中原有  old_dict = {      "#1":{ 'hostname':c1, 'cpu_count': 2, 'mem_capicity': 80 },      "#2":{ 'hostname':c1, 'cpu_count': 2, 'mem_capicity': 80 }      "#3":{ 'hostname':c1, 'cpu_count': 2, 'mem_capicity': 80 }  }      # cmdb 新彙報的數據  new_dict = {      "#1":{ 'hostname':c1, 'cpu_count': 2, 'mem_capicity': 800 },      "#3":{ 'hostname':c1, 'cpu_count': 2, 'mem_capicity': 80 }      "#4":{ 'hostname':c2, 'cpu_count': 2, 'mem_capicity': 80 }  }  需要刪除:?  需要新建:?  需要更新:?   注意:無需考慮內部元素是否改變,只要原來存在,新彙報也存在,就是需要更新