Rumah >pembangunan bahagian belakang >Tutorial Python >Pengendalian Ralat & Pembalakan di Python

Pengendalian Ralat & Pembalakan di Python

Jennifer Aniston
Jennifer Anistonasal
2025-03-06 11:44:13331semak imbas

Error Handling & Logging in Python

Dalam pembangunan perisian Python, pelbagai jenis kesilapan akan ditemui, seperti kesilapan sintaks, kesilapan logik dan kesilapan runtime.

ralat sintaks biasanya berlaku pada peringkat awal pembangunan program dan disebabkan oleh sintaks yang salah. Kesalahan sintaks mudah ditemui semasa menyusun program.

Kesalahan logik disebabkan oleh pelaksanaan logik yang tidak betul, seperti program yang mengakses senarai yang tidak disusun tetapi mengandaikan bahawa ia disusun. Kesalahan logik adalah salah satu jenis kesilapan yang paling sukar untuk dijejaki.

ralat runtime adalah kesilapan biasa, biasanya berlaku kerana semua situasi sempadan tidak dipertimbangkan. Sebagai contoh, cuba mengakses fail yang tidak wujud.

Tutorial ini akan menerangkan cara menangani kesilapan dalam Python dan bagaimana log log log untuk memahami masalah dengan lebih baik dalam permohonan anda. Kami akan merangkumi topik berikut:

    Gunakan
  • dan try untuk mengendalikan pengecualian except
  • Pengendalian Pengecualian Pelbagai
  • ayat finally
  • Pengecualian Custom
  • pembalakan python
  • Dapatkan Maklumat Jejak Stack

Pengendalian Pengecualian Python

Mari kita mulakan dengan program tambahan Python yang mudah. Program ini mengambil dua parameter sebagai input dan mencetak jumlah mereka:

def addNumbers(a, b):
    print(a + b)

addNumbers(5, 10)
Jalankan program di atas dan jumlah kedua -dua nombor akan dicetak.

Membuat kelas pengecualian tersuai dapat meningkatkan kebolehbacaan dan kebolehkerjaan program anda. Sebagai contoh, katakan terdapat program yang perlu memastikan bahawa harga diskaun item tidak lebih tinggi daripada harga jualan, kami boleh membuat pengecualian tersuai untuk jenis ralat ini:

class PriceError(Exception):
    pass
Kemudian, tambahkan pengendalian pengecualian ke program:

def discount(price, discounted_price):
    if discounted_price > price:
        raise PriceError
    else:
        print("Discount applied")
Dalam kod di atas, jika

lebih besar daripada discounted_price, pengecualian akan dibangkitkan. price PriceError

Pembalakan python

Modul Python's

menyediakan mekanisme untuk merakam maklumat yang menjalankan program, termasuk mesej ralat. Kita boleh menetapkan tahap log yang berbeza seperti debug, maklumat, amaran, kesilapan, dan kritikal. Coretan kod berikut menunjukkan cara merakam maklumat menggunakan modul

: logging logging

Tetapkan tahap log ke maklumat, dan maklumat log pada tahap maklumat dan di atas (termasuk amaran, kesilapan dan kritikal) akan direkodkan.
import logging

# 初始化日志设置
logging.basicConfig(filename='app.log', level=logging.INFO)

try:
    # ...你的代码...
except Exception as e:
    logging.exception(str(e))

mendapatkan maklumat jejak stack

Dalam contoh di atas, hanya ada satu fail program, jadi mudah untuk mencari di mana ralat berlaku. Walau bagaimanapun, sangat penting untuk mendapatkan maklumat jejak stack yang salah apabila banyak fail program terlibat. Anda boleh menggunakan kaedah

untuk merakam maklumat jejak stack pengecualian, seperti yang ditunjukkan di bawah:

logging.exception()

Jika program di atas dijalankan dan pengecualian berlaku, mesej ralat akan dilog masuk ke fail log, yang mengandungi maklumat jejak timbunan.
import logging

# 初始化日志设置
logging.basicConfig(filename='app.log', level=logging.INFO)

try:
    filePointer = open('appFile', 'r')
    try:
        content = filePointer.readline()
    finally:
        filePointer.close()
except IOError as e:
    logging.exception(str(e))

Ringkasan

Tutorial ini memperkenalkan kaedah asas pengendalian ralat python dan pembalakan, termasuk penggunaan try, except dan finally pernyataan dan aplikasi modul logging. Adalah disyorkan untuk membaca dokumentasi rasmi untuk maklumat yang lebih terperinci.

Dokumen ini telah dikemas kini dan mengandungi sumbangan dari Esther Vaati. Esther adalah pemaju perisian dan penyumbang kepada Envato Tuts.

Atas ialah kandungan terperinci Pengendalian Ralat & Pembalakan di Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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