一. python代码的调试方式

  1. 使用print语句打印出来
  2. 在编辑工具中,加断点跟踪(打断点)
  3. 使用日志模块,输出到日志中

下面我们来看一下如何打断点

二. 环境

python 3.4.4 + Pycharm Professional Edition 2018.1,注意这里尽量用新的版本,能用专业版尽量用专业版,功能更丰富

三. 调试代码

__author__ = '小翟'

'''1、自动贩卖机: 只接受1元、5元、10元的纸币或硬币,最多不超过10块钱。

    饮料只有橙汁、椰汁、矿泉水、早餐奶,售价分别是3.5,4,2,4.5。

   写一个函数用来表示贩卖机的功能: 用户投钱和选择饮料,并通过判断之后,给用户吐出饮料和找零。

   说明:参数有一个为金额,此金额为输入的总金额。
   -------------------------------------------------------------------
   -------------------------------------------------------------------
   '''

drink_price = {
    "橙汁": 3.5,
    "椰汁": 4,
    "矿泉水": 2,
    "早餐奶": 4.5
}

def auto_fanmaiji(money, drink_name):
    if money <= 10:
        for drink, price in drink_price.items():
            if drink_name == drink:
                if money > price:
                    print("请取出饮料: %s" % drink_name)
                    print("应找您%3.1f元" % (money - price))
                elif money == price:
                    print("请取出饮料: %s" % drink_name)
                else:
                    print("sorry, 您的金额不足以买:%s" % drink_name)
            else:
                continue
    else:
        print("sorry, 本机最大金额不能超过10元,请重试!")

auto_fanmaiji(7.3, "橙汁")

四. 打断点图解

python文件设置断点运行 python如何打断点_子函数

五. Step Over, Step Into和Step Out的区别

Step Over:在单步执行时,在函数内遇到子函数时不会进入子函数内单步执行,而是将子函数整个执行完再停止,也就是把子函数整个作为一步

注意:在不存在子函数的情况下Step Over是和Step Into效果一样的

Step Into:单步执行,遇到子函数就进入并且继续单步执行(即进入子函数)

Step Out:当单步执行到子函数内时,用Step Out就可以执行完子函数余下部分,并返回到上一层函数

在第14行调用devide函数时打断点

python文件设置断点运行 python如何打断点_子函数_02


实例1:Step Over的效果

python文件设置断点运行 python如何打断点_子函数_03

实例2:Step Into的效果

python文件设置断点运行 python如何打断点_python_04

点击Step Into下一步

python文件设置断点运行 python如何打断点_子函数_05


点击Step Into下一步

python文件设置断点运行 python如何打断点_python_06

点击Step Into下一步

python文件设置断点运行 python如何打断点_python_07

实例3:Step Out的效果

python文件设置断点运行 python如何打断点_编辑工具_08