前端框架选型是企业提升开发效率与用户体验的关键因素
1031
2022-11-01
vardbg 一个简单的Python调试器和探查器,可生成程序流程的动画可视化效果,对算法学习很有用
vardbg
A simple Python debugger and profiler that generates animated visualizations of program flow. It is meant to help with learning algorithms by allowing you to visualize what the algorithms are doing.
Python 3.6 or newer is required due to the use of f-strings.
This project was created during Google Code-in 2019 for CCExtractor Development.
Demo
Features
Tracking the history of each variable and its contentsTracking elements within containers (lists, sets, dicts, etc.)Ignoring specific variablesProfiling the execution of each lineSummarizing all variables and execution times after executionPassing arguments to debugged programsExporting execution history in jsON format and replaying (including program output)Creating videos that show program flow, execution times, variables (with relationships), and outputWriting videos in MP4, GIF, and WebP formats
Installation
The latest tagged version can be obtained from PyPI:
pip install vardbg
Alternatively, one can clone this repository and run it directly after installing dependencies:
git clone https://github.com/CCExtractor/vardbgcd vardbgpython3 -m venv venvsource venv/bin/activatepip install poetrypoetry install ../debug.py
It can also be installed from the repository:
pip install .
The above instructions assume the use of a virtual environment to avoid interfering with the system install of Python.
Usage
All of the debugger's subcommands and options are documented in the usage help, which is readily available on the command line.
For example, this command will debug the function quick_sort from the file sort.py with the arguments 9 3 5 1 and record the session to a JSON file named sort1.json:
vardbg run sort.py quick_sort -o qsort.json -a 9 -a 3 -a 5 -a 1
A video can then be generated from the above recording:
vardbg replay qsort.json -v sort_vis.mp4
It is possible to generate videos live while running the debugged program, but this is discouraged because the overhead of video creation inflates execution times greatly and thus ruins profiler results. However, if profiling is not important to you, it is a valid use case.
Configuration
The video generator has many options: resolution, speed, fonts, and sizes. These options can be modified using a TOML config file. The default config documents the available options, which can be customized in an minimal overlay config without having to duplicate the entire config. The config can then be used by passing the -c argument on the command line.
An example of a simple overlay is the config used to generate official demo videos for embedding in READMEs. This simple config increases the speed (FPS) slightly and adds an intro screen at the beginning of the video.
Behavior Control
Special comments can be added to lines of code that define variables to control how vardbg handles said variable:
# vardbg: ignore — do not display this variable or track its values# vardbg: ref lst[i] — treat variable i as the index/key of an element in container lst (only shown in videos)
Specifying the name of the variable may appear to be redundant, but there are two reasons behind this: reliably parsing all code that defines variables is very hard (there are more possible methods than one might think — loops, unpacking, direct assignments, exec calls, etc.), and more than one variable can be declared on a line. For example, tuple unpacking and function arguments are common occurrences of multiple variables being added on a single line. Thus, specifying the variable name in references is mandatory to prevent ambiguity.
Contributing
Feel free to contribute to this project! You can add features, fix bugs, or make any other improvements you see fit. We just ask that you follow the code style guidelines to keep the code consistent and coherent. These guidelines can easily be enforced before pushing with the pre-commit framework, which can install Git pre-commit hooks with the pre-commit install command.
Once your contribution meets the guidelines, open a pull request to make things official.
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~