sys模塊 1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 import sys 4 ''' 5 sys.argv : 在命令行參數是一個空列表,在其他中第一個列表元素程式本身的路徑 6 sys.exit(n) :退出程式,正常退出時exit(0 ...
sys模塊
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 import sys 4 ''' 5 sys.argv : 在命令行參數是一個空列表,在其他中第一個列表元素程式本身的路徑 6 sys.exit(n) :退出程式,正常退出時exit(0) 7 sys.version :獲取python解釋程式的版本信息 8 sys.path :返回模塊的搜索路徑,初始化時使用 python PATH環境變數的值 9 sys.platform :返回操作系統平臺的名稱 10 sys.stdin :輸入相關 11 sys.stdout :輸出相關 12 sys.stderror :錯誤相關 13 ''' 14 print(sys.argv) # ['H:/pythons3_/2019-02-17-面向對象進階/sys複習.py'] 15 print(sys.version) # 3.7.2 (tags/v3.7.2:9a3ffc0492, Dec 23 2018, 23:09:28) [MSC v.1916 64 bit (AMD64)] 16 print(sys.path) # ['H:\\pythons3_\\2019-02-17-面向對象進階', 'H:\\pythons3_', 'D:\\Python\\insert3\\python37.zip', 'D:\\Python\\insert3\\DLLs', 'D:\\Python\\insert3\\lib', 'D:\\Python\\insert3', 'D:\\Python\\insert3\\lib\\site-packages', 'D:\\Python\\ide\\PyCharm 2018.2.4\\helpers\\pycharm_matplotlib_backend'] 17 print(sys.platform) # win32import sys
os模塊
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 import os 4 ''' 5 os.getcwd() :獲取當前工作目錄,即當前Python腳本工作的目錄路徑 6 os.chdir('dirname') :改變當前腳本工作目錄;相當於shell下的cd 7 os.curdir :返回當前目錄:('.') 8 os.pardir : 獲取當前目錄的父目錄字元串名('..') 9 os.makedirs('dirname1/dirname2') :可生成多層遞歸目錄 10 os.removedirs('dirname1') :若目錄為空,則刪除,並遞歸到上一級目錄,如若也為空,則刪除 11 os.mkdir('dirname') :生成單級陌路;相當於shell中的mkdir dirname 12 os.rmdir('dirname') :刪除單級空目錄,若目錄不為空則無法刪除,報錯;相當於shell中rmdir dirname 13 os.listdir('dirname') :列出指定目錄下的所有文件和子目錄,包括隱藏目錄,並以列表方式列印 14 os.remove() :刪除一個文件 15 os.rename('oldname', 'newname') :重命名文件/目錄 16 os.stat('path/filename') :獲取文件/目錄信息 17 os.sep :輸出當前平臺使用的行終止符,win下為“\\”,Linux下為“/” 18 os.linesep :輸出當前平臺使用的行終止符,win下為“\t\n”,Linux下為“\n” 19 os.pathsep :輸出用於分割文件路徑的字元串win下為“;”,Linux下為“:” 20 os.name :輸出字元串指示當前使用平臺。win->“nt”,Linux->“posix” 21 os.system('bash command') :運行shell命令,直接顯示 22 os.environ :獲取系統環境變數 23 os.path.abspath(path) :返回path規範化的絕對路徑 24 os.path.split(path) :將path分割成目錄和文件名二元組返回 25 os.path.dirname(path) :返回path的目錄,其實就是os.path.split(path)的第一個元素 26 os.path.basename(path) :返回path最後的文件木 27 ''' 28 # print(os.getcwd()) # H:\pythons3_\2019-02-17-面向對象進階 29 # os.chdir(r'C:\\') # 前面小r 轉義的意思,將一個“\”轉換為“\\” 30 # print(os.getcwd()) # C:\ 31 # os.makedirs(r'aa\bb\cc') # 生成多層遞歸目錄 32 # os.removedirs(r'aa\bb\cc') # 遞歸刪除目錄 33 # print(os.listdir(os.getcwd())) # 列出指定目錄下的所有文件和子目錄;['os複習.py', 'sys複習.py'] 34 # print(os.stat('os複習.py')) # os.stat_result(st_mode=33206, st_ino=3096224743817390, st_dev=245858372, st_nlink=1, st_uid=0, st_gid=0, st_size=1816, st_atime=1550417104, st_mtime=1550417104, st_ctime=1550417104) 35 # print(os.stat(r'C:\Users\Administrator\Desktop\ASCII表.jpg').st_size) # 獲取文件/圖片大小信息;376278 36 # print(os.environ) # environ({'ALLUSERSPROFILE': 'C:\\ProgramData', 'APPDATA': 'C:\\Users\\Administrator\\AppData\\Roaming', 'ASL.LOG': 'Destination=file', 'COMMONPROGRAMFILES': 'C:\\Program Files\\Common Files', 'COMMONPROGRAMFILES(X86)': 'C:\\Program Files (x86)\\Common Files', 'COMMONPROGRAMW6432': 'C:\\Program Files\\Common Files', 'COMPUTERNAME': 'MAC', 'COMSPEC': 'C:\\Windows\\system32\\cmd.exe', 'FPS_BROWSER_APP_PROFILE_STRING': 'Internet Explorer', 'FPS_BROWSER_USER_PROFILE_STRING': 'Default', 'HOMEDRIVE': 'C:', 'HOMEPATH': '\\Users\\Administrator', 'LOCALAPPDATA': 'C:\\Users\\Administrator\\AppData\\Local', 'LOGONSERVER': '\\\\MAC', 'NUMBER_OF_PROCESSORS': '8', 'OS': 'Windows_NT', 'PATH': 'D:\\Python\\安裝\\;D:\\Python\\安裝\\Scripts;C:\\Windows\\system32;C:\\Windows;C:\\Windows\\System32\\Wbem;C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\;E:\\sql2008 x86共用\\100\\Tools\\Binn\\;E;\\sql2008共用\\100\\Tools\\Binn\\;E;\\sql2008共用\\100\\DTS\\Binn\\;E;\\sql2008 x86共用\\100\\Tools\\Binn\\VSShell\\Common7\\IDE\\;C;\\Program Files (x86)\\Microsoft Visual Studio 9.0\\Common7\\IDE\\PrivateAssemblies\\;E:\\sql2008 x86共用\\100\\DTS\\Binn\\;%;SERPROFILE%\\.dnx\\bin;C:\\Program Files\\Microsoft DNX\\Dnvm\\;C:\\Program Files\\Microsoft SQL Server\\130\\Tools\\Binn\\;C:\\Program Files\\Microsoft SQL Server\\120\\Tools\\Binn\\;C:\\Program Files (x86)\\nodejs\\;C:\\Program Files\\Git\\cmd;C:\\Program Files (x86)\\Windows Kits\\10\\Windows Performance Toolkit\\;E:\\sql2008 x86共用\\90\\Tools\\binn\\;C:\\Users\\Administrator\\AppData\\Local\\Programs\\Python\\Launcher\\;C:\\Users\\Administrator\\AppData\\Roaming\\npm;D:\\Python\\insert;D:\\Python\\insert3', 'PATHEXT': '.COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH;.MSC', 'PROCESSOR_ARCHITECTURE': 'AMD64', 'PROCESSOR_IDENTIFIER': 'Intel64 Family 6 Model 142 Stepping 10, GenuineIntel', 'PROCESSOR_LEVEL': '6', 'PROCESSOR_REVISION': '8e0a', 'PROGRAMDATA': 'C:\\ProgramData', 'PROGRAMFILES': 'C:\\Program Files', 'PROGRAMFILES(X86)': 'C:\\Program Files (x86)', 'PROGRAMW6432': 'C:\\Program Files', 'PSMODULEPATH': 'C:\\Windows\\system32\\WindowsPowerShell\\v1.0\\Modules\\', 'PUBLIC': 'C:\\Users\\Public', 'PYCHARM_HOSTED': '1', 'PYCHARM_MATPLOTLIB_PORT': '35491', 'PYTHONIOENCODING': 'UTF-8', 'PYTHONPATH': 'D:\\Python\\ide\\PyCharm 2018.2.4\\helpers\\pycharm_matplotlib_backend;H:\\pythons3_', 'PYTHONUNBUFFERED': '1', 'SESSIONNAME': 'Console', 'SYSTEMDRIVE': 'C:', 'SYSTEMROOT': 'C:\\Windows', 'TEMP': 'C:\\Users\\ADMINI~1\\AppData\\Local\\Temp', 'TMP': 'C:\\Users\\ADMINI~1\\AppData\\Local\\Temp', 'USERDOMAIN': 'MAC', 'USERDOMAIN_ROAMINGPROFILE': 'MAC', 'USERNAME': 'Administrator', 'USERPROFILE': 'C:\\Users\\Administrator', 'VS100COMNTOOLS': 'e:\\vs2010 64位\\安裝\\Common7\\Tools\\', 'VS110COMNTOOLS': 'C:\\Program Files (x86)\\Microsoft Visual Studio 11.0\\Common7\\Tools\\', 'VS120COMNTOOLS': 'C:\\Program Files (x86)\\Microsoft Visual Studio 12.0\\Common7\\Tools\\', 'VS140COMNTOOLS': 'E:\\C#安裝2015\\Common7\\Tools\\', 'VS90COMNTOOLS': 'E:\\vs 2008 c語言\\安裝\\Common7\\Tools\\', 'VSSDK140INSTALL': 'E:\\C#安裝2015\\VSSDK\\', 'WINDIR': 'C:\\Windows'}) 37 # os.system('dir') 38 # print(__file__) # 當前文件所在的文件名;H:/pythons3_/2019-02-17-面向對象進階/os複習.py 39 # print(os.path.abspath(__file__)) 40 # print(os.path.split(__file__)) # ('H:/pythons3_/2019-02-17-面向對象進階', 'os複習.py')import os
isinstance(obj,cls):檢查obj是否是類cls的對象,返回布爾值:True/False
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 5 class Foo: 6 pass 7 8 9 class FooTest: 10 pass 11 12 13 obj = Foo() 14 print(isinstance(obj, Foo)) # True 15 print(isinstance(obj, FooTest)) # Falseisinstance(obj,cls)
issubclass(sub,super):檢查sub類是否是super類的派生類,返回布爾值:True/False
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 5 class Foo: 6 pass 7 8 9 class Bar(Foo): 10 pass 11 12 13 print(issubclass(Bar, Foo)) # True 14 print(issubclass(Foo, Bar)) # Falseissubclass(sub,super)
__setitem__,__getitem__,__delitem__
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 5 class Foo: 6 def __getitem__(self, item): 7 print('getitem') 8 return self.__dict__[item] 9 10 def __setitem__(self, key, value): 11 print('setitem') 12 self.__dict__[key] = value 13 14 def __delitem__(self, key): 15 print('delitem') 16 self.__dict__.pop(key) 17 18 19 20 f1 = Foo() 21 # print(f1.__dict__) # {} 22 f1.name = 'alex' 23 f1['age'] = 16 # setitem 24 f1['name'] # getitem 25 del f1['name'] # delitem 26 print(f1.__dict__) # {'name': 'alex', 'age': 16}item系列
str和repr
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 5 class Foo: 6 def __str__(self): 7 return '自定製的對象的顯示方式' 8 9 10 f1 = Foo() 11 print(f1) # 自定製的對象的顯示方式 12 13 14 class Foo2: 15 def __init__(self, name, age): 16 self.name = name 17 self.age = age 18 19 def __str__(self): 20 return '姓名:%s,年齡:%s' % (self.name, self.age) 21 22 23 f2 = Foo2('alex', 15) 24 print(f2) # 姓名:alex,年齡:15 25 26 27 # repr 在解釋器中有用 28 class Foo3: 29 def __init__(self, name, age): 30 self.name = name 31 self.age = age 32 33 def __repr__(self): 34 return '姓名:%s,年齡:%s' % (self.name, self.age)str和repr
format
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 x = '{0}{0}{0}'.format('alex') 5 print(x) # alexalexalex 6 7 8 class Date: 9 def __init__(self, year, month, day): 10 self.year = year 11 self.month = month 12 self.day = day 13 14 15 d1 = Date(2019, 2, 18) 16 y = '{0.year}{0.month}{0.day}'.format(d1) 17 print(y) # 2019218 18 19 20 format_dic = { 21 'y:m:d': '{0.year}:{0.month}:{0.day}', 22 'm-d-y': '{0.month}-{0.day}-{0.year}' 23 } 24 25 26 class Date2: 27 def __init__(self, year, month, day): 28 self.year = year 29 self.month = month 30 self.day = day 31 32 def __format__(self, format_spec): 33 if not format_spec: 34 format_spec = 'y-m-d' 35 fmt = format_dic[format_spec] 36 return fmt.format(self) 37 38 39 d2 = Date2(2019, 2, 18) 40 print(format(d2, 'y:m:d')) # 2019:2:18format
__slots__
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 ''' 4 1.__slots__:是一個類變數,變數值可以是列表,元祖,或者可迭代對象,也可以是字元串(滋味著所有勢力只有數據屬性) 5 2.使用“.”來訪問屬性本質上就是訪問類或者對象的__dict__屬性字典(類的字典是共用的,而每個實例是獨立的) 6 3.為何使用 __slots__:字典會占用大量記憶體,如果你有一個屬性很少的類。但是有很多實例,為了節省記憶體可以使用__slots__取代實例的__dict__ 7 當你定義__slots__後,__slots__就會為實例使用一種更加緊湊的內部表示,實例通過一個很小的固定大小的數組來構建,而不是為每個勢力定義一個 8 字典,這跟元組或列表很類似。在__slots__中列出的屬性名在內部被映射到這個數組的指定小標上,使用__slots__一個不好的地方就是我們不能再給實例添加新的屬性了, 9 只能使用__slots__中定義的那些屬性名。 10 4.註意事項:__slots__的很多特性都依賴於普通的基於字典的實現。另外,定義了__slots__後的類不在支持一些普通類特性了。比如繼承。 11 大多數情況下,你應該只在那些經常被使用到的用作數據結構的類上定義__slots__比如在程式中需要創建某個類的幾百萬個實例對象。 12 關於__slots__的一個常見誤區是:它可以作為一個封裝工具來防止用戶給實例添加新的屬性。儘管使用__slots__可以達到這樣的目的,但是這個並不是初衷。---->更多的是用來作為一個記憶體優化工具。 13 ''' 14 class Foo: 15 # __slots__ = ['name', 'age'] # <==>{'name':None,'age':None} 16 __slots__ = 'name' 17 18 19 f1 = Foo() 20 f1.name = 'alex' 21 print(f1.name) 22 # print(f1.__dict__) # 報錯。因為__slots__定義後取代了__dict__ 23 print('---->', f1.__slots__) # ----> name 24 # f1.age = 18 # 報錯__slots__
__doc__
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 # __doc__:文檔註釋 5 class Foo: 6 '我是描述信息' 7 pass 8 9 10 print(Foo.__doc__) # 我是描述信息__doc__
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 5 # __doc__:文檔註釋 6 class Foo: 7 '我是描述信息' 8 pass 9 10 11 class Bar(Foo): 12 pass 13 14 15 print(Bar.__doc__) # None,不能被繼承文檔註釋__doc__不能被繼承
__del__
析構方法,當對象在記憶體中被 釋放時,自動觸發執行。
註:此方法一般無須定義,因為Python是一個高級語言。程式員在使用時無需關心記憶體的分配和釋放,因為此工作都是交給Python解釋器來執行,所以,析構函數的調用時由解釋器在進行垃圾回收時自動觸發執行的。
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 5 class Foo: 6 def __init__(self, name): 7 self.name = name 8 9 def __del__(self): 10 print('析構函數已經執行') 11 12 13 f1 = Foo('alex') 14 del f1 15 print('----->') 16 ''' 17 執行結果如下: 18 析構函數已經執行 19 -----> 20 '''__del__
__call__
對象後面加括弧,觸發執行。
註:構造方法的執行是由創建對象觸發的,即:對象=類();而對於__call__方法的執行是由對象後加括弧觸發的,即:對象()或者類()
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 5 class Foo: 6 def __call__(self, *args, **kwargs): 7 print('實例執行了') 8 9 10 f1 = Foo() 11 f1() # 實例執行了;調用了Foo下的__call____call__
描述符應用,限制用戶輸入數據類型
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 4 5 class Typed: 6 def __init__(self, key): 7 self.key = key 8 9 def __get__(self, instance, owner): 10 return instance.__dict__[self.key] 11 12 def __set__(self, instance, value): 13 # if not type(value) is str: 14 if not isinstance(value, str): 15 # print('你輸入數據類型不是str') 16 # return 17 raise TypeError('你輸入數據類型不是str') 18 instance.__dict__[self.key] = value 19 20 def __delete__(self, instance): 21 instance.__dict__.pop(self.key) 22 23 24 class People: 25 name = Typed('name') 26 27 def __init__(self, name, age): 28 self.name = name 29 self.age = age 30 31 32 p1 = People(11, 15) # 報錯;你輸入數據類型不是str 33 print(p1.__dict__) # {'age': 15} 34 p2 = People('alex', 16) 35 print(p1.__dict__) # {'age': 15}