python記錄_day019 類的約束 異常處理 日誌

来源:https://www.cnblogs.com/zhang-yl/archive/2018/11/12/9948996.html
-Advertisement-
Play Games

一 、約束 python中約束有兩種 第一種,通過拋異常進行約束,這種是子類不按我要求的來,我就給你拋異常(推薦) 操作:提取一個父類. 在父類中給出一個方法。但在方法中不給出任何代碼,直接拋異常 1 # 貼吧 2 # 項目經理(級別高一點兒) 3 class Base: 4 def login(s ...


一 、約束

python中約束有兩種

第一種,通過拋異常進行約束,這種是子類不按我要求的來,我就給你拋異常(推薦)

操作:提取一個父類. 在父類中給出一個方法。但在方法中不給出任何代碼,直接拋異常

 1  # 貼吧
 2  # 項目經理(級別高一點兒)
 3  class Base:
 4      def login(self): # 強制子類做xxxx事
 5          raise NotImplementedError("子類沒有實現該方法") # 報錯. 拋異常
 6 
 7  # 1. 普通賬號  -->  翔哥
 8  class Normal(Base):
 9      def login(self):
10          print("普通賬號的登錄")
11 
12  # 2. 吧務  - > 強哥
13  class Member(Base):
14      def login(self):
15          print("吧務的登錄")
16 
17  # 3. 百度員工  -> 明哥
18  class Admin(Base):
19      def denglu(self): 
20          print("管理員的登錄")
21 
22  # 項目經理
23  def wodetian(obj):
24      obj.login()
25 
26  n = Normal()
27  wodetian(n)
28 
29  m = Member()
30  wodetian(m)
31 
32  a = Admin()
33  wodetian(a)   #這就會拋出異常,因為沒按要求寫,找不到login
異常約束

 

第二種,通過抽象類和抽象方法進行約束,這種是子類不按我要求的來,我就不讓子類實例化

操作:提取一個父類,將父類中給出的方法定義為抽象方法,不必實現,直接pass

### 這些概念要記住:

抽象類是不能進行實例化的

如果一個類中有抽象方法,那麼這個類就是抽象類

一個抽象類可以有非抽象方法

 1 from abc import ABCMeta, abstractmethod
 2 
 3 class Base(metaclass=ABCMeta): # 抽象類
 4      # 抽象方法
 5      @abstractmethod
 6      def login(self):          # 強制子類做xxxx事,子類必須重寫這個方法
 7          pass
 8 
 9 class Normal(Base):
10     def login(self):
11         print("普通登錄")
12 
13 class Member(Base):
14     def login(self):
15         print("會員登錄")
16 
17 class Admin(Base):
18     def denglu(self):
19         print('管理員登錄')
20 
21 def denglu(obj):
22     obj.login()
23 n = Normal()
24 denglu(n)
25 m = Member()
26 denglu(m)
27 a = Admin()  #Can't instantiate abstract class admin with abstract methods login
28 denglu(a)
抽象約束

 

二、異常處理

格式:

try:

  代碼塊

except  錯誤名 as 別名:

  出現該錯誤時做什麼

except 錯誤名 as  別名:

  出現該錯誤時做什麼

...

else:

  不出錯時執行這裡

finally:

  出不出錯都執行這裡

解讀: 程式先執行操作, 然後如果出錯了會走except中的代碼. 如果不出錯, 執行else中的代碼. 不論出不出錯. 最後都要執行finally中的語句. 一般我們用try...except就夠了. 頂多加上finally. finally一般用來作為收尾工作。

 1 def cul(a,b):
 2     if (type(a)== int or type(a) == float) and (type(b)== int or type(b)== float):
 3         return a+b
 4     else:
 5         raise Exception("我要的是數字,你輸入的是啥")
 6 
 7 try:
 8     print(cul("",4))
 9 except Exception as e:
10     print("錯了,你要輸入數字")
異常處理

 

##拋異常

拋異常要用到關鍵字raise

 1 def add(a, b):
 2  '''
 3  給我傳遞兩個整數. 我幫你計算兩個數的和
 4  :param :param a:
 5  :param :param b:
 6  :return :return:
 7  '''
 8  if not type(a) == int and not type(b) == int:
 9  # 當程式運行到這句話的時候. 整個函數的調用會被中斷. 並向外拋出一個異常.
10  raise Exception("不是整數, 朕不能幫你搞定這麼複雜的運算.")
11  return a + b
12 # 如果調用方不處理異常. 那產生的錯誤將會繼續向外拋. 最後就拋給了用戶
13 add("你好", "我叫賽利亞")
14 # 如果調用方處理了異常. 那麼錯誤就不會丟給用戶. 程式也能正常進行
15 try:
16  add("胡辣湯", "滋滋冒油的大腰子")
17 except Exception as e:
18  print("報錯了. 我要的是數字")
raise

 

##自定義異常

 非常簡單. 只要你的類繼承了Exception類. 那你的類就是一個異常類

格式:

def  異常名(Exception):

  pass

 1 #自定義異常
 2 class GenderException(Exception):
 3     pass
 4 
 5 class Person:
 6 
 7     def __init__(self,name,gender):
 8         self.name = name
 9         self.gender = gender
10 
11     def goto_nan(self):
12         if self.gender !="":
13             raise GenderException("性別不對")
14         else:
15             print("歡迎光臨")
16 try:
17     p1 = Person('alex', '')
18     p1.goto_nan()
19 
20     p2 = Person('妖姬', '')
21     p2.goto_nan()
22 
23 except GenderException as e:
24     print("你來錯地兒了")
25 except Exception as e:
26     print("其他錯誤")
自定義異常

 

##異常處理好是好,但是有一個問題,我們在調試的時候是希望看到程式哪裡出現問題的,而異常處理沒有具體的錯誤信息,那這麼辦呢?這時需要引入另一個模塊traceback. 這個模塊可以獲取到我們每個方法的調用信息. 又被稱為堆棧信息. 這個信息對我們排錯是很有幫助的.

 1 import traceback
 2 
 3 # 繼承Exception. 那這個類就是一個異常類  自定義異常
 4 class GenderError(Exception):
 5      pass
 6 class Person:
 7      def __init__(self, name, gender):
 8          self.name = name
 9          self.gender = gender
10 
11 def nan_zao_tang_xi_zao(person):
12      if person.gender != "":
13          raise GenderError("性別不對. 這裡是男澡堂子")
14 
15 p1 = Person("alex", "")
16 p2 = Person("eggon", "")
17 # nan_zao_tang_xi_zao(p1)
18 # nan_zao_tang_xi_zao(p2) # 報錯. 會拋出一個異常: GenderError
19 
20 # 處理異常
21 try:
22      nan_zao_tang_xi_zao(p1)
23      nan_zao_tang_xi_zao(p2)
24 except GenderError as e:
25      val = traceback.format_exc() # 獲取到堆棧信息
26      print(e) # 性別不對. 這裡是男澡堂子
27      print(val)
28 except Exception as e:
29      print("反正報錯了")        
30 結果:
31 性別不對. 這裡是男澡堂子
32 Traceback (most recent call last):
33  File "/Users/sylar/PycharmProjects/oldboy/面向對象/day05.py", line 155, in
34 <module>
35      nan_zao_tang_xi_zao(p2)
36  File "/Users/sylar/PycharmProjects/oldboy/面向對象/day05.py", line 144, in
37 nan_zao_tang_xi_zao
38      raise GenderError("性別不對. 這裡是男澡堂子")
39 GenderError: 性別不對. 這裡是男澡堂子
View Code

這樣我們就能收放放如了. 當測試代碼的時候把堆棧信息列印出來. 但是當到了 線上的生產環境的時候把這個堆棧去掉即可

 

三、日誌(不用記,知道怎麼用就行)

當出現任何錯誤的時候. 我們都可以去日誌系統里去查. 看哪裡出了問題. 這樣在解決問題和bug的時候就多了一個幫手。

那如何在python中創建這個日誌系統呢? 

1. 導入logging模塊.

2. 簡單配置一下logging

3. 出現異常的時候(except). 嚮日志里寫錯誤信息.

 1 #參數解釋
 2 # filename: 文件名
 3 # format: 數據的格式化輸出. 最終在日誌文件中的樣子
 4 # 時間-名稱-級別-模塊: 錯誤信息
 5 # datefmt: 時間的格式
 6 # level: 錯誤的級別權重, 當錯誤的級別權重大於等於leval的時候才會寫入文件
 7 
 8 import logging  #導入模塊
 9 #簡單配置,一般只需修改level值
10 logging.basicConfig(filename='x1.txt',
11  format='%(asctime)s - %(name)s - %(levelname)s -%
12 (module)s: %(message)s',
13  datefmt='%Y-%m-%d %H:%M:%S',
14 level=0) # 當前配置表示 0以上的分數會被寫入文件
15 # CRITICAL = 50
16 # FATAL = CRITICAL
17 # ERROR = 40
18 # WARNING = 30
19 # WARN = WARNING
20 # INFO = 20
21 # DEBUG = 10
22 # NOTSET = 0
23 logging.critical("我是critical") # 寫入critical級別信息
24 logging.error("我是error") # 寫入error級別信息
25 logging.warning("我是警告") # 警告 
26 logging.info("我是基本信息") # 
27 logging.debug("我是調試")  
28 logging.log(2, "我是自定義") # 自定義.  第一個參數可以自己給值,第二個是往日誌文件里寫的內容
 1  1 import logging
 2  2 
 3  3 logging.basicConfig(filename='x1.log',
 4  4      format='%(asctime)s - %(name)s - %(levelname)s -%(module)s: %(message)s',
 5  5      datefmt='%Y-%m-%d %H:%M:%S',
 6  6     level=35)  # 當前配置表示 35以上的級別會被寫入文件
 7  7 
 8  8 import traceback
 9  9 try:
10 10     print(1/0)
11 11 except Exception:
12 12     logging.error(traceback.format_exc()) # 寫入error信息
13 13     logging.log(36, traceback.format_exc())  # 自定義寫入
14 14     print("出錯了")
15 15 結果:
16 16 x1.txt內容
17 17 
18 18 2018-11-12 20:43:01 - root - ERROR -日誌系統: Traceback (most recent call last):
19 19   File "D:/PyCharm/workspace/day019 約束/日誌系統.py", line 29, in <module>
20 20     print(1/0)
21 21 ZeroDivisionError: division by zero
22 22 
23 23 2018-11-12 20:43:01 - root - Level 36 -日誌系統: Traceback (most recent call last):
24 24   File "D:/PyCharm/workspace/day019 約束/日誌系統.py", line 29, in <module>
25 25     print(1/0)
26 26 ZeroDivisionError: division by zero
日誌應用

 

##

最後, 如果你系統中想要把日誌文件分開. 比如. 有個大項目, 有兩個子系統, 那兩個子系 統要分開記錄日誌. 方便調試. 那怎麼辦呢? 註意. 用上面的basicConfig是搞不定的. 我們要藉助文件助手(FileHandler), 來幫我們完成日誌的分開記錄

 1 import logging
 2 
 3 # 創建一個操作日誌的對象logger(依賴FileHandler)
 4 file_handler = logging.FileHandler('l1.log', 'a', encoding='utf-8')
 5 file_handler.setFormatter(logging.Formatter(fmt="%(asctime)s - %(name)s - %(levelname)s -%(module)s: %(message)s"))
 6 
 7 logger1 = logging.Logger('a系統', level=logging.ERROR)  #級別
 8 logger1.addHandler(file_handler)   #把文件助手和日誌對象綁定
 9 logger1.error('我是A系統')   #寫入日誌信息
10 
11 # 再創建一個操作日誌的對象logger(依賴FileHandler)
12 file_handler2 = logging.FileHandler('l2.log', 'a', encoding='utf-8')
13 file_handler2.setFormatter(logging.Formatter(fmt="%(asctime)s - %(name)s -%(levelname)s -%(module)s: %(message)s"))
14 
15 logger2 = logging.Logger('b系統', level=logging.ERROR)  #級別
16 logger2.addHandler(file_handler2)
17 logger2.error('我是B系統')  #寫入日誌信息
日誌分開

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • python 3.5+ 版本 python2版本 在字典中如果有重覆的key值,從左向右開始複製,也就是最先複製的值會被覆蓋掉 ...
  • 對於JDK要配置三個環境變數,分別是JAVA_HOME、path、classpath 對於我本人電腦來說,配置如下: JAVA_HOME:C:\Program Files\Java\jdk1.8.0_191;(JDK的安裝路徑) path: %JAVA_HOME%\bin;%JAVA_HOME%\j ...
  • 恢復內容開始 C++11 新特性 借鑒於 https://www.cnblogs.com/feng-sc/p/5710724.html C++ 2011/2014 統稱 C++2.0 1.auto關鍵字 auto這個關鍵字,是一個自動檢測類型的關鍵字,當類型很複雜時,無法確定變數/參數類型時,可以使 ...
  • Python編程語言非常強大,非常容易上手,版本更新也不慢,在win10 x64中相容性也很好,直接安裝不需另外配置,雖然Python2和3有點異同。學習的話選擇最新的 python 3.7.1版。 系統是win 10 X64.到官網去下載 最新版 Python 3.7.1 1.建議下載execut ...
  • 隨著互聯網的興起,web開發變得愈發的重要。Python作為當前火熱的語言, 其中的web開發框架可以說是百花齊放,下麵聊一聊這些框架。 一: 基於Python的代表性Web框架 "Django" Django是一個開放源代碼的Web應用框架,由Python寫成。採用了MTV的框架模式,即模型M,模 ...
  • M:model代表的是應用的業務邏輯,通過Javabeen,EJB實現, V:view代表的是應用的表示面,有jsp頁面產生 C:controller提供應用的處理過程機制,一般是一個servlet,通過這種設計模型把應用邏輯,處理過程和顯示邏輯分成不同的組件實現。這些組件可以進行交互和重用 Jav ...
  • 1、一行代碼實現1-100的和 2、如何在一個函數內修改全局變數的值 3、字典如何刪除鍵和合併兩個字典 4、說一說對python的GIL的理解 GIL是python的全局解釋器鎖,在一個進程中如果有多個線程執行,其中一個線程在執行的時候會霸占python解釋器(加鎖即GIL),那麼其他線程就不能執行 ...
  • WIN7系統,VC2010下。 程式A靜態鏈接B.dll動態庫。 B.dll中導出3個類: (1) 基類 class AFX_EXT_CLASS base { public: base(){}; virtual ~base(){}; virtual int getX() = 0; protected ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...