python-study-17

復習

上節課復習1、什么是模塊模塊是一系列功能的集合體2、為何用模塊拿來(內置或第三方的模塊)主義,提升開發效率自定義模塊可以讓程序的各部分組件重用模塊內的功能3、如何用模塊大前提:模塊是被執行文件導入使用,模塊的導入必須搞明白誰是執行文件,誰是被導入的模塊import首次import m1導入模塊都發生三件事:1、先創建一個模塊的名稱空間2、執行m1.py,將執行過程中產生的名稱都放入模塊的名稱空間中3、在當前執行文件中拿到一個名字m1,該名字是指向模塊的名稱空間使用方法:指名道姓地訪問m1名稱空間中的名字func,優點是不會與當前名稱空間中的名字沖突,缺點是每次訪問都需要加上前綴m1.funcfrom ... import首次from m1 import func導入模塊都發生三件事:1、先創建一個模塊的名稱空間2、執行m1.py,將執行過程中產生的名稱都放入模塊的名稱空間中3、在當前執行文件中直接拿到一個功能名func,該名字是直接指向模塊名稱空間中的某一個功能的使用方法:直接使用功能即可,優點是無需加任何前綴,缺點是容易與當前名稱空間中的名字沖突def func():passfunc()4、模塊的搜索路徑內存-》內置模塊-》sys.path5、軟件開發的目錄規范今日內容1、模塊的另外一種形式->包(****2、常用模塊logging日志模塊時間模塊random模塊json與pickle模塊
View Code

?

1、什么是包包是模塊的一種形式,包的本質就是一個含有__init__.py文件的文件夾2、為什么要有包3、如何用包導入包就是在導包下的__init__.pyimport ...from ... import...注意的問題:1、包內所有的文件都是被導入使用的,而不是被直接運行的2、包內部模塊之間的導入可以使用絕對導入(以包的根目錄為基準)與相對導入(以當前被導入的模塊所在的目錄為基準)推薦使用相對導入3、當文件是執行文件時,無法在該文件內用相對導入的語法只有在文件時被當作模塊導入時,該文件內才能使用相對導入的語法4、凡是在導入時帶點的,點的左邊都必須是一個包import aaa.bbb.m3.f3 # 錯誤
View Code

?

日志模塊

# import logging
# 進行基本的日志配置
# logging.basicConfig(filename='access.log',
#                     format='%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s',
#                     datefmt='%Y-%m-%d %H:%M:%S %p',
#                     level=10,
#                     # stream=True
#                     )# 日志級別遵循原則:自下而上進行匹配 #debug-》info-》warning-》error-》critical
# logging.debug('調試信息') #10
# logging.info('正常信息') #20
# logging.warning('不好啦著火啦') #30
# logging.error('報錯信息') #40
# logging.critical('嚴重錯誤信息') #50# 問題:
#1、沒有指定日志級別
#2、沒有指定日志格式
#3、只能往屏幕打印,沒有寫入文件# 新問題
#1、不能指定字符串編碼
#2、只能往文件中打印import logging
# logging模塊包含四種角色:logger,filter,formatter,handler
#1、logger:負責產生日志信息
logger1=logging.getLogger('交易日志')
# logger2=logging.getLogger('用戶相關')#2、filter:負責篩選日志#3、formatter:控制日志輸出格式
formatter1=logging.Formatter(fmt='%(asctime)s:%(name)s:%(levelname)s:%(message)s',datefmt='%Y-%m-%d %X'
)
formatter2=logging.Formatter(fmt='%(asctime)s:%(message)s',datefmt='%Y-%m-%d %X'
)#4、handler:負責日志輸出的目標
h1=logging.FileHandler(filename='a1.log',encoding='utf-8')
h2=logging.FileHandler(filename='a2.log',encoding='utf-8')
sm=logging.StreamHandler()#5、綁定logger對象與handler對象
logger1.addHandler(h1)
logger1.addHandler(h2)
logger1.addHandler(sm)#6、綁定handler對象與formatter對象
h1.setFormatter(formatter1)
h2.setFormatter(formatter1)
sm.setFormatter(formatter2)#7、設置日志級別:可以在兩個關卡進行設置logger與handler
logger1.setLevel(10)
h1.setLevel(10)
h2.setLevel(10)
sm.setLevel(10)logger1.info('Egon借給李杰100W')
View Code
"""
logging配置
"""
import os
import logging.config# 定義三種日志輸出格式 開始
standard_format = '%(asctime)s - %(filename)s:%(lineno)d - %(levelname)s - %(message)s'simple_format = '%(asctime)s - %(levelname)s - %(message)s'id_simple_format = '[%(asctime)s] %(message)s'# log文件的全路徑
logfile1_path = r'D:\SH_fullstack_s2\day17\a1.log'
logfile2_path = r'D:\SH_fullstack_s2\day17\a2.log'# log配置字典
LOGGING_DIC = {'version': 1,'disable_existing_loggers': False,'formatters': {'formatter1': {'format': standard_format},'formatter2': {'format': simple_format},},'filters': {},'handlers': {#打印到終端的日志'sm': {'level': 'DEBUG','class': 'logging.StreamHandler',  # 打印到屏幕'formatter': 'formatter2'},#打印到文件的日志,收集info及以上的日志'h1': {'level': 'DEBUG','class': 'logging.FileHandler',  # 保存到文件'formatter': 'formatter1','filename': logfile1_path,  # 日志文件'encoding': 'utf-8',  # 日志文件的編碼,再也不用擔心中文log亂碼了
        },'h2': {'level': 'DEBUG','class': 'logging.FileHandler',  # 保存到文件'formatter': 'formatter1','filename': logfile2_path,  # 日志文件'encoding': 'utf-8',  # 日志文件的編碼,再也不用擔心中文log亂碼了
        },},'loggers': {#logging.getLogger(__name__)拿到的logger配置'logger1': {'handlers': ['h1','h2','sm'],'level': 'DEBUG','propagate': False,  # 向上(更高level的logger)傳遞
        },},
}
logging的用法

?

轉載于:https://www.cnblogs.com/xujinjin18/p/9198956.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/452269.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/452269.shtml
英文地址,請注明出處:http://en.pswp.cn/news/452269.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

面向對象方法學的優點

1.與人類習慣的思維方法一致面向對象的軟件技術以對象為核心,用這種技術開發出的軟件系統由對象組成。對象是由描述內部狀態表示靜態屬性的數據,以及可以對這些數據施加的操作(對象的動態行為),封裝在一起所構成的統一體。面向對象的設計方法…

如何學好C語言

我相信,這可能是很多朋友的問題,我以前也有這樣的感覺,編程編到一定的時候,發現能力到了瓶頸,既不深,也不扎實,半吊子。比如:你長期地使用Java和.NET ,這些有虛擬機的語言…

學成在線--5.CMS頁面管理開發(修改頁面)

文章目錄1.修改頁面流程1)前端邏輯2)后端邏輯2.修改頁面接口定義3.后端開發--Dao4.后端開發--Service5.后端開發--Controller1)根據id查詢頁面2)保存頁面信息6.前端開發--頁面處理流程7.前端開發--編寫page_edit.vue8.前端開發--配…

在樹莓派上播放音頻

https://blog.csdn.net/qinxiandiqi/article/details/39155593轉載于:https://www.cnblogs.com/Baronboy/p/9206164.html

Map四種獲取key和value值的方法,以及對map中的元素排序

2019獨角獸企業重金招聘Python工程師標準>>> 獲取map的值主要有四種方法,這四種方法又分為兩類: 一類是調用map.keySet()方法來獲取key和value的值, 另一類則是通過map.entrySet()方法來取值, 兩者的區別在于,前者主要…

配置Oracle Instant Client環境

1.配置Oracle Instant Client環境 到Oracle官網下載Oracle Instant Client,注意選擇x86平臺,Toad只認32位的Oracle Instant Client。至于版本號,沒有特別要求,版本向下兼容。 桌面上,右鍵點“我的電腦”,選…

學成在線--6.CMS頁面管理開發(刪除頁面)

文章目錄0.刪除用戶邏輯1.刪除頁面接口定義2.后端開發--Dao3.后端開發--Service4.后端開發--controller5.前端開發--page_list.vue添加刪除按鈕6.前端開發--page_list.vue編寫刪除事件7.后端開發--Api方法定義Api方法0.刪除用戶邏輯 1)前端邏輯 (1&…

諾基亞是“不跟隨”還是跟不上?

在Android和iPhone為主流的環境下,諾基亞用“不跟隨”的口號表明自己欲保持個性,但是否也意味著其固步自封,跟不上時代? 5年市值縮水超900億歐元,全球業績連續4個季度虧損,更為可怕的是,被視為…

HTTP 協議(詳解)

HTTP協議簡介:HTTP協議是Hyper Text Transfer Protocol(超文本傳輸協議)的縮寫,是用于萬維網(www.world wide web)服務器與本地瀏覽器之間傳輸文本的傳輸協議。 http請求協議與相應協議HTTP協議包含瀏覽器發送數據到服務器需要遵循…

對象的特點

對象有如下一些基本特點。(1) 以數據為中心。操作圍繞對其數據所需要做的處理來設置,不設置與這些數據無關的操作,而且操作的結果往往與當時所處的狀態 (數據的值)有關。 (2) 對象是主動的。它是進行處理的主體。不能從外部直接加工它的私有數據&a…

React Native集成Redux框架講解與應用

學過React Native的都知道,RN的UI是根據相應組件的state進行render的,而頁面又是由大大小小的組件構成,導致每個組件都必須維護自身的一套狀態,因此當頁面復雜化的時候,管理state會相當吃力的。而redux提供了一套機制來…

【筆試記錄】2021/3/10阿里

阿里20210310春招筆試記錄-Python解題 第一題 問題描述: 小偷從出發點按指定方向出發,除非遇到墻或超出城市必須轉方向,不然只能直走。城市大小m*n。輸入描述: 1. 第1行,三個數字m n k;m*n表示城市大小&…

Spring mvc中@RequestMapping 6個基本用法小結

前些天發現了一個巨牛的人工智能學習網站,通俗易懂,風趣幽默,忍不住分享一下給大家。點擊跳轉到教程。 小結下spring mvc中的RequestMapping的用法。 1)最基本的,方法級別上應用,例如: …

學成在線--7.CMS頁面管理開發(異常處理)

文章目錄1.異常處理的問題分析2.異常處理流程3.可預知異常處理1.自定義異常類2.異常拋出類3.異常捕獲類4.異常處理測試1)定義錯誤代碼2)異常處理測試4.不可預知異常處理1.定義異常捕獲方法1)異常拋出測試2)異常捕獲方法1.異常處理…

函數重載與運算符重載

有兩種重載:函數重載是指在同一作用域內的若干個參數特征不同的函數可以使用相同的函數名字;運算符重載是指同一個運算符可以施加于不同類型的操作數上面。就是對已有的運算符重新進行定義,賦予其另一種功能,以適應不同的數據類型…

Django(6)

為什么不用_set related_name和related_query_name的區別related_name將成為相關對象的屬性,允許您使用外鍵對模型進行“倒退”。例如,如果ModelA有像下面這樣的字段,那么model_b ForeignKeyField(ModelB, related_namemodel_as)這將使您能夠…

P5 RV1126編碼測試Demo

目錄 前言 01 測試Demo大致流程圖 02 代碼分析 2.1 VI設備初始化 2.2 使能通道 —— RK_MPI_VI_EnableChn 2.3 VI 和 VENC綁定 2.4 創建 編碼線程 前言 從本章開始我們將要學習嵌入式音視頻的學習了 ,使用的瑞芯微的開發板 🎬 個人主頁&#xff1a…

MP算法和OMP算法及其思想

主要介紹MP(Matching Pursuits)算法和OMP(Orthogonal Matching Pursuit)算法[1],這兩個算法雖然在90年代初就提出來了,但作為經典的算法,國內文獻(可能有我沒有搜索到)都僅描述了算法步驟和簡單的應用,并未對其進行詳盡的分析&…

【牛客刷題記錄】2021-03-10

牛客代碼刷題記錄1 問題一 給定一個數組序列, 需要求選出一個區間, 使得該區間是所有區間中經過如下計算的值最大的一個: 區間中的最小數 * 區間所有數的和最后程序輸出經過計算后的最大值即可,不需要輸出具體的區間。如給定序列 [6 2 1]則根據上述公式…

SpringMVC詳細示例實戰教程

一、SpringMVC基礎入門&#xff0c;創建一個HelloWorld程序 1.首先&#xff0c;導入SpringMVC需要的jar包。 2.添加Web.xml配置文件中關于SpringMVC的配置 123456789101112131415<!--configure the setting of springmvcDispatcherServlet and configure the mapping-->&…