찾다
백엔드 개발파이썬 튜토리얼Python 디버깅: 로깅 및 pdb(예제 분석 2)

이전 글에서는 Python을 디버깅해야 하는 이유를 알아보고 Python 디버깅의 두 가지 방법을 소개했습니다. 하지만 디버깅 방법은 한 글에서 설명할 수 없으므로 이번 글에서는 나머지 두 가지 디버깅 방법에 대해 설명하겠습니다. 이러한 디버깅 방법이 여러분에게 도움이 되기를 바라며 Python 학습의 길에서 더 빠르게 나아갈 수 있도록 도와주기를 바랍니다.

logging

세 번째 방법은 print()를 로깅으로 바꾸는 것입니다. Assert와 비교하면 로깅은 오류를 발생시키지 않으며 파일로 출력할 수 있습니다.

import logging
s = '0'
n = int(s)
logging.info('n = %d' % n)
print(10 / n)

logging.info( )는 다음과 같은 내용을 출력할 수 있습니다. 텍스트. 실행하고 ZeroDivisionError를 제외한 정보를 찾지 마십시오. 무슨 일이야?

걱정하지 마세요. 로깅을 가져온 후 구성 줄을 추가하고 다시 시도하세요.

import logging
logging.basicConfig(level=logging.INFO)

출력 보기:

$ python err.py
INFO:root:n = 0
Traceback (most recent call last):
  File "err.py", line 8, in <module>
    print(10 / n)
ZeroDivisionError: division by zero

이것은 로깅의 이점입니다. 디버그를 포함한 로깅 정보 수준을 지정할 수 있습니다. info, warning 및 error 몇 레벨을 기다린 후 level=INFO를 지정하면 login.debug가 작동하지 않습니다. 같은 방식으로 level=WARNING을 지정한 후에는 디버그 및 정보가 작동하지 않습니다. 이런 방식으로 다양한 수준의 정보를 삭제하지 않고도 안전하게 출력할 수 있으며 최종적으로 어떤 수준의 정보가 출력되는지 제어할 수 있습니다.

로깅의 또 다른 이점은 간단한 구성을 통해 명령문을 콘솔, 파일 등 여러 위치에 동시에 출력할 수 있다는 것입니다.

pdb

네 번째 방법은 Python 디버거 pdb를 시작하고 프로그램을 단일 단계 모드에서 실행한 후 언제든지 실행 상태를 확인할 수 있는 것입니다. 먼저

# err.py
s = &#39;0&#39;
n = int(s)
print(10 / n)

프로그램을 준비한 다음 시작합니다.

$ python -m pdb err.py
> /Users/michael/Github/learn-python3/samples/debug/err.py(2)<module>()
-> s = &#39;0&#39;

-m pdb 매개변수로 시작한 후 pdb는 다음에 실행될 코드를 찾습니다 -> 코드를 보려면 l 명령을 입력하세요.

 (Pdb) l
  1     # err.py
  2  -> s = &#39;0&#39;
  3     n = int(s)
  4     print(10 / n)

코드를 단계별로 보려면 n 명령을 입력하세요.

(Pdb) n
> /Users/michael/Github/learn-python3/samples/debug/err.py(3)<module>()
-> n = int(s)
(Pdb) n
> /Users/michael/Github/learn-python3/samples/debug/err.py(4)<module>()
-> print(10 / n)

언제든지 p 변수 이름 명령을 입력하여 변수를 볼 수 있습니다.

(Pdb) p s
&#39;0&#39;
(Pdb) p n
0

q 명령을 입력하여 코드를 확인하세요. 디버깅을 끝내고 프로그램을 종료하세요:

(Pdb) q

(pdb를 통해 명령줄에서 디버깅하는 이 방법은 이론적으로는 만능이지만 실제로는 너무 번거롭습니다.)

위 내용은 이 글의 내용을 모두 소개한 것입니다. python 디버깅에 대한 지식, 위 내용을 이해하는 데 해당 정보를 활용할 수 있기를 바랍니다. 이 글에서 제가 설명한 내용이 여러분에게 도움이 되고 파이썬을 더 쉽게 배울 수 있기를 바랍니다.

더 많은 관련 지식을 알고 싶으시면 PHP 중국어 홈페이지의 Python tutorial 칼럼을 방문해 주세요.

위 내용은 Python 디버깅: 로깅 및 pdb(예제 분석 2)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
如何使用php扩展XDebug进行强大的调试和性能分析如何使用php扩展XDebug进行强大的调试和性能分析Jul 28, 2023 pm 07:45 PM

如何使用PHP扩展Xdebug进行强大的调试和性能分析引言:在开发PHP应用程序的过程中,调试和性能分析是必不可少的环节。而Xdebug是PHP开发者常用的一款强大的调试工具,它提供了一系列高级功能,如断点调试、变量跟踪、性能分析等。本文将介绍如何使用Xdebug进行强大的调试和性能分析,以及一些实用的技巧和注意事项。一、安装Xdebug在开始使用Xdebu

Laravel开发:如何使用Laravel Tinker进行交互式调试?Laravel开发:如何使用Laravel Tinker进行交互式调试?Jun 13, 2023 pm 04:33 PM

Laravel是一个流行的PHP框架,它提供了一种叫做Tinker的交互式命令行工具。Tinker是通过命令行与应用交互的一种简单而强大的方式,使用它可以轻松地测试和调试Laravel应用程序。本文将介绍如何在Laravel中使用Tinker进行交互式调试,包括如何安装和使用它。安装TinkerTinker是Laravel的默认包,因此它已经包含在了Lara

使用GDB调试Linux内核的常用配置技巧使用GDB调试Linux内核的常用配置技巧Jul 05, 2023 pm 01:54 PM

使用GDB调试Linux内核的常用配置技巧引言:在Linux开发中,使用GDB调试内核是一项非常重要的技能。GDB是一款功能强大的调试工具,可以帮助开发者快速定位和解决内核中的bug。本文将介绍一些常用的GDB配置技巧,以及如何使用GDB调试Linux内核。一、配置GDB环境首先,我们需要在Linux系统上配置GDB的环境。请确保你的系统已经安装了GDB工具

Python 2.x 中如何使用pdb模块进行代码调试Python 2.x 中如何使用pdb模块进行代码调试Aug 01, 2023 pm 12:05 PM

Python2.x中如何使用pdb模块进行代码调试引言:在软件开发过程中,我们往往会遇到程序错误、变量值不符合预期或意外结果等问题。为了解决这些问题,我们需要对代码进行调试。Python中提供了强大的pdb(Pythondebugger)模块,可以帮助我们快速定位问题并进行调试。本文将介绍如何在Python2.x中使用pdb模块进行代码调试,并且附上

Linux下使用GDB调试多线程程序的常见配置方法Linux下使用GDB调试多线程程序的常见配置方法Jul 04, 2023 pm 02:49 PM

Linux下使用GDB调试多线程程序的常见配置方法引言:在多线程编程中,调试是一项必不可少的工作。GDB是一个功能强大的调试器,可以帮助我们定位和解决多线程程序中出现的错误。本文将介绍在Linux下使用GDB调试多线程程序的常见配置方法,并配备代码示例,希望能帮助读者更好地理解和运用GDB。一、安装GDB首先,我们需要在Linux系统中安装GDB。在终端中输

调试和解决Linux网络连接问题调试和解决Linux网络连接问题Jun 30, 2023 pm 06:06 PM

如何调试和解决Linux系统中的网络连接问题在使用Linux系统过程中,我们经常会遇到网络连接问题,如无法访问互联网、无法连接到局域网、网速缓慢等。这对于依赖网络工作和学习的用户来说无疑是一个令人头疼的问题。本文将介绍一些常见的网络连接问题,并提供一些调试和解决的方法,帮助读者快速找到和解决问题。首先,我们需要先确定网络连接是否正常。可以使用命令ping来测

如何使用CakePHP中的调试输出?如何使用CakePHP中的调试输出?Jun 05, 2023 pm 12:10 PM

作为一个强大的PHP框架,CakePHP提供了许多工具来帮助开发者进行调试。其中,调试输出是一种非常重要的工具,可以帮助开发者快速定位代码中的问题。本文将介绍如何使用CakePHP中的调试输出。一、什么是调试输出调试输出是指在运行程序时输出调试信息。它可以帮助开发者在程序运行时对变量、对象、数组等进行检查,以便发现程序中存在的错误。在CakePHP中,使用调

C++中的反汇编技术与调试C++中的反汇编技术与调试Aug 22, 2023 am 11:06 AM

C++是一门广泛应用于系统开发的编程语言,它的广泛性与复杂性使得调试成为了C++开发者必不可少的技能。在C++技术的调试过程中,反汇编技术发挥着重要作用。本文将介绍C++中的反汇编技术与调试,以帮助C++开发者更好地理解和解决问题。一、反汇编技术1.什么是反汇编反汇编是一种将已编译的二进制机器代码文件转换回其原始汇编语言的过程。通过反汇编,开发者可以更好地理

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 영어 버전

SublimeText3 영어 버전

권장 사항: Win 버전, 코드 프롬프트 지원!

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경