Rumah pembangunan bahagian belakang Tutorial Python Rahsia modul pengelogan Python: Membuka kunci potensinya yang tidak terhad

Rahsia modul pengelogan Python: Membuka kunci potensinya yang tidak terhad

Mar 08, 2024 am 08:52 AM
nyahpepijat prestasi pembalakan kebolehselenggaraan

Python logging 模块的秘籍:解锁其无限潜力

Selami khazanah modul pembalakan Python

Modul pengelogan

python ialah alat yang berkuasa untuk merakam dan memproses aplikasi log Ia menyediakan pelbagai fungsi dan kebolehubahsuaian, membolehkan pembangun mengumpul maklumat berharga untuk penyahpepijatan, analisis dan Monitor. Artikel ini akan mendedahkan rahsia modul pengelogan Python, membuka kunci kuncinya dan membantu anda mencipta aplikasi yang teguh, boleh diselenggara dan cekap.

Tahap dan penapis: mengawal butiran maklumat log

Modul pengelogan membolehkan anda menggredkan mesej log berdasarkan keterukan mereka, daripada DEBUG kepada KRITIKAL. Anda boleh menggunakan penapis untuk mengawal mesej yang dilog dan diproses, dengan itu menghalang fail log anda daripada dibanjiri dengan maklumat yang tidak berkaitan. Contoh berikut menunjukkan cara mengkonfigurasi penapis untuk log hanya mesej peringkat DEBUG dan INFO:

import logging

# 设置日志级别
logging.basicConfig(level=logging.INFO)

# 创建一个过滤器,仅记录 DEBUG 和 INFO 消息
filter = logging.Filter()
filter.filter = lambda record: record.levelno in (logging.DEBUG, logging.INFO)

# 为根记录器添加过滤器
logging.getLogger().addFilter(filter)
Salin selepas log masuk

Pemformat: Sesuaikan pembentangan maklumat log

Modul pengelogan menyediakan satu siri pemformat untuk menyesuaikan pembentangan maklumat log. Anda boleh mengawal format mesej, format cap masa dan metadata lain. Dengan pemformat tersuai, anda boleh mencipta fail log yang bermakna dan boleh dibaca yang memudahkan untuk mengenal pasti dan menganalisis masalah dengan cepat. Contoh berikut menunjukkan cara membuat pemformat tersuai, menambah cap masa dan tahap mesej:

import logging

# 创建一个自定义格式化器
fORMatter = logging.Formatter("%(asctime)s - %(levelname)s - %(message)s")

# 为根记录器设置自定义格式化器
logging.getLogger().handlers[0].setFormatter(formatter)
Salin selepas log masuk

Pemproses: Hantar maklumat log ke destinasi berbeza

Modul

log membolehkan anda menghantar maklumat log ke destinasi berbeza seperti konsol, fail atau pelayan jauh. Dengan menggunakan pemproses, anda boleh mengawal penyimpanan dan pengedaran maklumat log secara fleksibel. Contoh berikut menunjukkan cara mengkonfigurasi pemproses untuk menulis maklumat log ke fail:

import logging

# 创建一个文件处理器,将日志信息写入文件
file_handler = logging.FileHandler("my_log.log")

# 为根记录器添加文件处理器
logging.getLogger().addHandler(file_handler)
Salin selepas log masuk

Hierarki pembalak: susun dan tapis maklumat log

Modul pengelogan menggunakan hierarki pengelog untuk menyusun dan menapis mesej log. Setiap pembalak mempunyai nama yang secara unik mengenal pasti kedudukannya dalam hierarki. Pembalak kanak-kanak mewarisi tetapan pembalak induk mereka melainkan dikonfigurasikan sebaliknya. Dengan menggunakan hierarki logger, anda boleh log maklumat dengan cara yang teratur dan mudah menapis maklumat yang tidak berkaitan dengan menetapkan penapis. Contoh berikut menunjukkan cara membuat sublogger dan menetapkan tahap log yang berbeza untuknya:

import logging

# 创建一个根记录器
root_logger = logging.getLogger()

# 创建一个子记录器,名称为 "my_module"
my_logger = logging.getLogger("my_module")

# 为子记录器设置不同的日志级别
my_logger.setLevel(logging.DEBUG)
Salin selepas log masuk

Pengurus Konteks: Ubah suai tetapan log buat sementara waktu

Modul pengelogan menyediakan pengurus konteks yang membolehkan anda mengubah suai tetapan pengelogan buat sementara waktu tanpa menjejaskan konfigurasi global. Ini berguna untuk mendayakan atau melumpuhkan pengelogan dalam blok kod tertentu. Contoh berikut menunjukkan cara untuk melumpuhkan pengelogan sementara menggunakan pengurus konteks:

import logging

with logging.disable(logging.CRITICAL):
# 在此代码块中禁用日志记录
pass
Salin selepas log masuk

Tingkatkan kualiti aplikasi dengan modul pengelogan Python

Dengan menguasai rahsia modul pengelogan Python, anda boleh meningkatkan kualiti aplikasi anda. Dengan mengawal butiran, pembentangan, penyimpanan dan penyusunan maklumat log dengan teliti, anda boleh mencipta aplikasi yang teguh, boleh diselenggara dan cekap yang mendapat manfaat daripada maklumat log terperinci.

Atas ialah kandungan terperinci Rahsia modul pengelogan Python: Membuka kunci potensinya yang tidak terhad. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana cara menggunakan LeakSanitizer untuk menyahpepijat kebocoran memori C++? Bagaimana cara menggunakan LeakSanitizer untuk menyahpepijat kebocoran memori C++? Jun 02, 2024 pm 09:46 PM

Bagaimana cara menggunakan LeakSanitizer untuk menyahpepijat kebocoran memori C++? Pasang LeakSanitizer. Dayakan LeakSanitizer melalui bendera kompilasi. Jalankan aplikasi dan analisis laporan LeakSanitizer. Kenal pasti jenis peruntukan memori dan lokasi peruntukan. Betulkan kebocoran memori dan pastikan semua memori yang diperuntukkan secara dinamik dikeluarkan.

Perbandingan prestasi rangka kerja Java yang berbeza Perbandingan prestasi rangka kerja Java yang berbeza Jun 05, 2024 pm 07:14 PM

Perbandingan prestasi rangka kerja Java yang berbeza: Pemprosesan permintaan REST API: Vert.x adalah yang terbaik, dengan kadar permintaan 2 kali SpringBoot dan 3 kali Dropwizard. Pertanyaan pangkalan data: HibernateORM SpringBoot adalah lebih baik daripada Vert.x dan ORM Dropwizard. Operasi caching: Pelanggan Hazelcast Vert.x lebih unggul daripada mekanisme caching SpringBoot dan Dropwizard. Rangka kerja yang sesuai: Pilih mengikut keperluan aplikasi Vert.x sesuai untuk perkhidmatan web berprestasi tinggi, SpringBoot sesuai untuk aplikasi intensif data, dan Dropwizard sesuai untuk seni bina perkhidmatan mikro.

Bagaimana untuk melakukan pengendalian ralat dan log masuk dalam reka bentuk kelas C++? Bagaimana untuk melakukan pengendalian ralat dan log masuk dalam reka bentuk kelas C++? Jun 02, 2024 am 09:45 AM

Ralat pengendalian dan log masuk dalam reka bentuk kelas C++ termasuk: Pengendalian pengecualian: menangkap dan mengendalikan pengecualian, menggunakan kelas pengecualian tersuai untuk memberikan maklumat ralat khusus. Kod ralat: Gunakan integer atau penghitungan untuk mewakili keadaan ralat dan mengembalikannya dalam nilai pulangan. Penegasan: Sahkan syarat pra dan pasca, dan buang pengecualian jika ia tidak dipenuhi. Pengelogan perpustakaan C++: pengelogan asas menggunakan std::cerr dan std::clog. Perpustakaan pengelogan luaran: Integrasikan perpustakaan pihak ketiga untuk ciri lanjutan seperti penapisan tahap dan putaran fail log. Kelas log tersuai: Buat kelas log anda sendiri, abstrak mekanisme asas dan sediakan antara muka biasa untuk merekodkan tahap maklumat yang berbeza.

Bagaimana untuk menjalankan ujian konkurensi dan penyahpepijatan dalam pengaturcaraan serentak Java? Bagaimana untuk menjalankan ujian konkurensi dan penyahpepijatan dalam pengaturcaraan serentak Java? May 09, 2024 am 09:33 AM

Ujian dan penyahpepijatan serentak Ujian dan penyahpepijatan serentak dalam pengaturcaraan serentak Java adalah penting dan teknik berikut tersedia: Ujian serentak: Ujian unit: Asingkan dan uji satu tugas serentak. Ujian integrasi: menguji interaksi antara pelbagai tugas serentak. Ujian beban: Nilaikan prestasi dan kebolehskalaan aplikasi di bawah beban berat. Penyahpepijatan Konkurensi: Titik Putus: Jeda pelaksanaan utas dan periksa pembolehubah atau jalankan kod. Pengelogan: Rekod peristiwa dan status urutan. Jejak tindanan: Kenal pasti sumber pengecualian. Alat visualisasi: Pantau aktiviti benang dan penggunaan sumber.

Bagaimana untuk mengoptimumkan prestasi program berbilang benang dalam C++? Bagaimana untuk mengoptimumkan prestasi program berbilang benang dalam C++? Jun 05, 2024 pm 02:04 PM

Teknik berkesan untuk mengoptimumkan prestasi berbilang benang C++ termasuk mengehadkan bilangan utas untuk mengelakkan perbalahan sumber. Gunakan kunci mutex ringan untuk mengurangkan perbalahan. Optimumkan skop kunci dan minimumkan masa menunggu. Gunakan struktur data tanpa kunci untuk menambah baik keselarasan. Elakkan sibuk menunggu dan maklumkan urutan ketersediaan sumber melalui acara.

Bagaimana untuk menyahpepijat kod tak segerak PHP Bagaimana untuk menyahpepijat kod tak segerak PHP May 31, 2024 am 09:08 AM

Alat untuk menyahpepijat kod tak segerak PHP termasuk: Psalm: alat analisis statik yang menemui kemungkinan ralat. ParallelLint: Alat yang memeriksa kod tak segerak dan memberikan cadangan. Xdebug: Sambungan untuk menyahpepijat aplikasi PHP dengan mendayakan sesi dan melangkah melalui kod. Petua lain termasuk menggunakan pengelogan, penegasan, kod berjalan secara setempat dan menulis ujian unit.

Ralat Penyahpepijatan PHP: Panduan untuk Kesilapan Biasa Ralat Penyahpepijatan PHP: Panduan untuk Kesilapan Biasa Jun 05, 2024 pm 03:18 PM

Ralat penyahpepijatan PHP biasa termasuk: Ralat sintaks: Semak sintaks kod untuk memastikan tiada ralat. Pembolehubah tidak ditentukan: Sebelum menggunakan pembolehubah, pastikan ia dimulakan dan diberikan nilai. Koma bertitik tiada: Tambahkan koma bertitik pada semua blok kod. Fungsi tidak ditentukan: Semak sama ada nama fungsi dieja dengan betul dan pastikan fail atau sambungan PHP yang betul dimuatkan.

Perbandingan prestasi C++ dengan bahasa lain Perbandingan prestasi C++ dengan bahasa lain Jun 01, 2024 pm 10:04 PM

Apabila membangunkan aplikasi berprestasi tinggi, C++ mengatasi bahasa lain, terutamanya dalam penanda aras mikro. Dalam penanda aras makro, kemudahan dan mekanisme pengoptimuman bahasa lain seperti Java dan C# mungkin berprestasi lebih baik. Dalam kes praktikal, C++ berprestasi baik dalam pemprosesan imej, pengiraan berangka dan pembangunan permainan, dan kawalan langsungnya terhadap pengurusan memori dan akses perkakasan membawa kelebihan prestasi yang jelas.

See all articles