Pycharm Debug调试

使用Pycharm,遇到问题,一开始只知道加个断点,然后一脸懵逼不知道怎么调试,花点时间把我摸索的过程整理下。
1.添加断点
一个断点标记了一个代码行,当Pycharm运行到该行代码时会将程序暂时挂起。通过单击代码左侧的空白槽来在对应位置生成断点。
Pycharm Debug调试_第1张图片
2.开始调试
点击Run—‘Debug XXX文件名’,或单击工具栏中蜘蛛图标,调试开始,并在第一个断点行停止,蓝色高亮显示当前调试行(蓝色说明Pycharm已击中该断点行,但尚未执行)。
Pycharm Debug调试_第2张图片
3.单步调试
step into:F7
若函数A内存在子函数a时,会进入子函数a内执行单步调试
step over:F8
若函数A内存在子函数a时,不会进入子函数a内执行单步调试,而是把子函数a当作一个整体,一步执行。
step out:Shift+F8
当目前执行在子函数a中时,选择该调试操作可以直接跳出子函数a,而不用继续执行子函数a中的剩余代码。并返回上一层函数。
run to cursor:Alt +F9
直接跳到下一个断点

4.添加一个变量查看器
我们在调试过程中观察变量的状态,需要对其设置一个查看器。在Watches窗口中,单击加号,输入期望查看的变量名称,例如这里输入woksheet.rows,然后回车。当然你也可以采用另外一种方式:在编辑窗口中右击变量名,在快捷菜单中选择Add to watches。稍后你将会看到如何对这个变量进行负值,以及其在watches窗口中的变化
Pycharm Debug调试_第3张图片
5.浏览帧
  此时你能看到一个名为MainThread的进程,其中包含三帧。单击每一帧来显示其变量状态以及相对应的py文件,同时会对有问题的代码行以高亮显示。
6.代码实例:
  在你的Python工程中,创建一个新的Python文件,命名为EditExcelFile.py,然后输入以下代码(功能概述:创建一个excel文件写入数据后插入数据,保存文档):

# coding=utf-8
import openpyxl
import os
path = 'C:\Users\Think\Desktop\python\myfile.xlsx'
#判断文件是否存在,存在删除
if os.path.exists(path):
    os.remove(path)

# 创建一个workbook对象,相当于创建了一个Excel文件
workbook = openpyxl.Workbook()
#wb = openpyxl.Workbook(encoding='UTF-8')

#获取当前活跃的worksheet,默认就是第一个worksheet
worksheet = workbook.active
worksheet.title = "mysheet"
    
#写入数据
Title = ['学号', '姓名', '成绩']
Name = ['张三', '王五', '赵柳', '李四', '王武', '周瑜', '郑旺']
StuNo = ['001', '002', '003', '004', '005', '006', '007']
Score = [100, 78, 89, 98, 64, 70, 95]

for i in range(len(Title)):
    worksheet.cell(1, i+1, Title[i])

for i in range(len(Name)):
    worksheet.cell(i+2, 1, Name[i])

for i in range(len(StuNo)):
    worksheet.cell(i+2, 2, StuNo[i])

for i in range(len(Score)):
    worksheet.cell(i+2, 3, Score[i])

#保存到工作薄
workbook.save(path)
#插入一列
workbook = openpyxl.load_workbook(path)
worksheet = workbook.worksheets[0]

#在第一列之前插入一列
worksheet.insert_cols(1)
for index, row in enumerate(worksheet.rows):
    if index == 0:
        row[0].value = "编号"
    else:
        row[0].value = index
workbook.save(path)
#枚举出来是tuple类型,从0开始计数

你可能感兴趣的:(#,学习记录)