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:
try
untuk mengendalikan pengecualian except
finally
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)
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
def discount(price, discounted_price): if discounted_price > price: raise PriceError else: print("Discount applied")
lebih besar daripada discounted_price
, pengecualian akan dibangkitkan. price
PriceError
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
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()
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 Dokumen ini telah dikemas kini dan mengandungi sumbangan dari Esther Vaati. Esther adalah pemaju perisian dan penyumbang kepada Envato Tuts. try
, except
dan finally
pernyataan dan aplikasi modul logging
. Adalah disyorkan untuk membaca dokumentasi rasmi untuk maklumat yang lebih terperinci.
Atas ialah kandungan terperinci Pengendalian Ralat & Pembalakan di Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!