検索
ホームページバックエンド開発Python チュートリアルPython デバッグ: ロギングと PDB (分析例 2)

前回の記事では、Python でデバッグが必要な理由を学び、Python のデバッグ方法を 2 つ紹介しましたが、デバッグ方法は 1 つの記事では説明しきれないため、この記事で説明します。残りの 2 つのデバッグ方法。これらのデバッグ方法がお役に立ち、Python の学習をより早く進めるのに役立つことを願っています。

logging

3 番目の方法は、print() を logging に置き換えることです。assert と比較して、logging はエラーをスローせず、ファイルに出力できます。 :

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

これはログの利点であり、これにより次のことが可能になります。レコードを指定します。情報のレベルには、デバッグ、情報、警告、エラーなどが含まれます。level=INFO を指定すると、logging.debug は機能しません。同様に、level=WARNING を指定すると、debug と info が機能しなくなります。このようにして、さまざまなレベルの情報を削除せずに安全に出力でき、最終的にどのレベルの情報を出力するかを制御できます。

ロギングのもう 1 つの利点は、簡単な構成で、ステートメントをコンソールやファイルなどの異なる場所に同時に出力できることです。

pdb

4 番目の方法は、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 は次に実行されるコードを見つけます -> s = ' 0' 。コードを表示するには、コマンド 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 デバッグ に関する関連知識を中心に紹介していますので、上記の内容を理解するために活用していただければ幸いです。この記事で説明したことがあなたのお役に立ち、Python の学習が容易になることを願っています。

関連知識の詳細については、php 中国語 Web サイトの Python チュートリアル 列を参照してください。

以上がPython デバッグ: ロギングと PDB (分析例 2)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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ヘンタイを無料で生成します。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境