系统环境:Ubuntu 18.04.1 LTS

Python使用的是虚拟环境:virutalenv

Python的版本:Python 3.6.9

简说Python之ipython

1.安装ipython

pip install ipython

2.ipython的使用

In [1]: run utils.py                                                                          

In [2]: cat utils.py
# coding=utf-8
import os
import hashlib
from functools import partial from config import UPLOAD_FOLDER HERE = os.path.abspath(os.path.dirname(__file__)) def get_file_md5(f, chunk_size=8192):
h = hashlib.md5()
while True:
chunk = f.read(chunk_size)
if not chunk:
break
h.update(chunk)
return h.hexdigest() def humanize_bytes(bytesize, precision=2):
abbrevs = (
(1 << 50, 'PB'),
(1 << 40, 'TB'),
(1 << 30, 'GB'),
(1 << 20, 'MB'),
(1 << 10, 'kB'),
(1, 'bytes')
)
if bytesize == 1:
return '1 byte'
for factor, suffix in abbrevs:
if bytesize >= factor:
break
return '%.*f %s' % (precision, bytesize / factor, suffix) get_file_path = partial(os.path.join, HERE, UPLOAD_FOLDER) In [3]: humanize_bytes(100)
Out[3]: '100.00 bytes' In [4]: humanize_bytes(430004)
Out[4]: '419.93 kB' In [5]: humanize_bytes(430004342342)
Out[5]: '400.47 GB'

这样可以不启动所有的py程序,直接测试某一个函数的功能。通过输入参数,得到输出。

函数的性质,把它看成一个黑盒子。测试它的输入输出。

humanize_bytes通过测试可以知道,它就是格式化数字,统计为多少字节,KB,MB,GB等。

3.ipython的debug调试。

python写了一个简单的递归程序

(zsdpy1) $ vi recursive.py
# coding=utf-8
def recu(n):
print ("level 1 value :",n);
if(n>2):
recu(n-1)
print ("--level 2 value :",n);
recu(5)

进入调试

In [4]: run -d recursive.py  

      1 # coding=utf-8
----> 2 def recu(n):
3 print ("level 1 value :",n);
4 if(n>2):
5 recu(n-1)
  • b设置断点命令,进入调试模式输入b xx(xx为行数)。
  • n命令单步执行,不会进入函数内部
  • s命令单步执行,会进入函数内部
  • a是打印出当前函数的参数值
  • j 是跳转到某一行执行有点类似b和c指令结合,具体使用j xx(xx为行数)
  • q,退出pdb调试模式

这里我们输入s命令,单步调试,看看这个递归程序是如何运行的。

ipdb> s
## 直接跳入到了recu(5)的过程
> /home/zsd/web_develop/recursive.py(8)<module>()
4 if(n>2):
5 recu(n-1)
6 print ("--level 2 value :",n);
7
----> 8 recu(5) ipdb> s
## 运行recu(n)的函数
> /home/zsd/web_develop/recursive.py(2)recu()
1 # coding=utf-8
----> 2 def recu(n):
3 print ("level 1 value :",n);
4 if(n>2):
5 recu(n-1)
## 输出函数值5
> /home/zsd/web_develop/recursive.py(3)recu()
1 # coding=utf-8
2 def recu(n):
----> 3 print ("level 1 value :",n);
4 if(n>2):
5 recu(n-1) ipdb> s
level 1 value : 5
> /home/zsd/web_develop/recursive.py(4)recu()
2 def recu(n):
3 print ("level 1 value :",n);
----> 4 if(n>2):
5 recu(n-1)
6 print ("--level 2 value :",n);
然后就会一直循环,到2的时候,在循环出来。有兴趣的可以s继续单步调试

其输出结果是:

level 1 value : 5
level 1 value : 4
level 1 value : 3
level 1 value : 2
--level 2 value : 2
--level 2 value : 3
--level 2 value : 4
--level 2 value : 5

简说Python之ipython的pdb调试的更多相关文章

  1. python学习笔记之pdb调试

    之前一直说要学python可还是一直停留在看的层面,昨天大神手把书教我pdb调试,说要摆脱IDE集成开发环境编程,感激不尽,立一个flag,python一定要入门! 1.进入方式 1)windows ...

  2. python学习笔记012——pdb调试

    1 描述 pdb 是 python 自带的一个包,为 python 程序提供了一种交互的源代码调试功能, 主要特性包括设置断点.单步调试.进入函数调试.查看当前代码.查看栈片段.动态改变变量的值等 调 ...

  3. PDB调试Python程序

    pdb是python内置的调试工具, 它可以在终端中调试Python程序, 这允许pdb在很多无法安装IDE的服务器上使用. 虽然远程调试使用广泛, 但在必要的时候(比如难以在本地搭建运行环境)pdb ...

  4. 使用pdb调试python

    python pdb调试 python -m pdb myscript.py #注意这会重启myscript.py,这样启动的话,代码每一行都是一个节点 也可以在程序中这么设置断点: import p ...

  5. python 用pdb调试

    简单调试 Python 程序   在 Python 中也可以像 gcc/gdb 那样调试程序,只要在运行 Python 程序时引入 pdb 模块(假设要调试的程序名为 d.py): $ vi d.py ...

  6. python pdb调试以及sublime3快捷键设置

    python pdb调试以及sublime3快捷键设置 pdb调试 如果对gdb比较熟悉的话,pdb就很容易上手.以一个demo快速了解常用的调试命令. def test(a): while True ...

  7. Python 代码使用pdb调试技巧

    Debug 对于任何开发人员都是一项非常重要的技能,它能够帮助我们准确的定位错误,发现程序中的 bug.python 提供了一系列 debug 的工具和包,可供我们选择.本文将主要阐述如何利用 pyt ...

  8. [Python学习笔记][第八章Python异常处理结构与程序调试]

    1/30 第八章Python异常处理结构与程序调试 异常处理 try-except结构 try: try块 except Exception: except块 try-except-else结构 tr ...

  9. pdb 调试

    以前写python一直用pycharm,调试啥的比较方便,最近要在远程服务器上调试一些程序,只有一个控制台就可以用pdb进行调试了.常用的只有几个命令. break 或 b 设置断点 continue ...

  10. 在 Python 中使用 GDB 来调试 转载

    2013/11/01 | Comments 大约一年前,我接触了 Java 中的 Btrace 能够不停机查看线上 JVM 运行情况的特性让我艳羡不已. 另外还有强悍的 jStack 和 jConso ...

随机推荐

  1. verilog之random

    verilog之random 1.基本作用 random,用于产生随机数.在测试时,有时需要测试的情况太多,无法一一列举,就需要使用抽样测试的方法验证功能是否可行.random是一个有返回值的系统函数 ...

  2. 【已解决】Hadoop_03 解决Hadoop输入jps没有NameNode的问题

    问题描述: 解决方案: 1.先运行 stop-all.sh 2.格式化 namdenode(在这之前要先删除原目录,即core-site.xml下配置的<name>hadoop.tmp.d ...

  3. #单调栈#CodeChef Meteor

    METEORAK 分析 设 \(dp[l][r]\) 表示第 \(l\) 到 \(r\) 行的答案,可以发现它由 \(f[l][r],dp[l][r+1],dp[l+1][r]\) 转移而来. 关键就 ...

  4. Python 集合(Sets)1

    集合 集合用于在单个变量中存储多个项.集合是 Python 中的 4 种内置数据类型之一,用于存储数据集合,其他 3 种是列表(List).元组(Tuple)和字典(Dictionary),它们都具有 ...

  5. std::thread 五:打包任务(packaged_task)

    #include <iostream> #include <thread> #include <mutex> #include <list> #incl ...

  6. 建议收藏!Harmony应用配置文件概述(Stage模型)

    一. 应用配置文件 每个应用项目必须在项目的代码目录下加入配置文件,这些配置文件会向编译工具.操作系统和应用市场提供应用的基本信息. 在基于Stage模型开发的应用项目代码下,都存在一个app.jso ...

  7. 重新点亮shell————函数[七]

    前言 简单整理一下函数. 正文 自定义函数: function fname(){ 命令 } 函数的执行: fname 函数作用范围的变量: local 变量名 函数的参数 $1 $2 $3 .... ...

  8. 重新点亮shell————什么是shell[一]

    前言 这里简介一下什么是shell. 写linux和shell 系列是为了后面的docker 系列的整理,本来想直接整理k8s的,但是呢,想想docker 系列整理完了的话,那么整理k8s系列就没有那 ...

  9. redis 简单整理——redis 的有序集合基本结构和命令[六]

    前言 简单介绍一下redis的有序集合的基本结构和命令. 正文 有序集合相对于哈希.列表.集合来说会有一点点陌生,但既然叫有序 集合,那么它和集合必然有着联系,它保留了集合不能有重复成员的特性, 但不 ...

  10. 重新整理 .net core 实践篇—————grpc工具[三十四]

    前言 简单整理一下grpc工具. 正文 工具核心包: Grpc.Tools 这个是项目要引用的包,用来生成cs代码的. dotnet-grpc 这个就是cli,命令行工具 dotnet-grpc 核心 ...