IndentationError: unindent does not match any outer indentation level笔记
2019-07-14 13:06 潇湘隐者 阅读(376108) 评论(3) 编辑 收藏 举报
执行一个Python脚本的时候,报“IndentationError: unindent does not match any outer indentation level" 错误,搜索了一下相关资料,遇到这个错误,是因为新的Python语法中是不支持的代码对齐中,混用TAB和空格的。
# python get_mssql_job_info.py
File "get_mssql_job_info.py", line 29
db_sub_conn = pymssql.connect(host=row[1],
^
IndentationError: unindent does not match any outer indentation level
如上所示,可以使用Notepad++打开脚本,勾选“显示空格与制表符”,此时你会看到代码对齐使用了制表符与空格
我用空格替换了制表符后,发现还是报这个错误,最后发现报错行上面注释的地方也要注意代码对齐,而我代码里面上面的'''使用制表符, 下面的'''使用空格。所以这里也必须一致
解决方法:
1: 使用工具pycharm 有个快捷键 CTRL+ALT+L格式化代码。
2: 在Notepad++的首先项里面,可以勾选“替换为空格”,如下所示,不同版本的Notepad++,可能设置选项有所出入。这样可以避免使用Tab+空格键时出现这种情况。
后面我又遇到了下面“IndentationError: unexpected indent”这个错误:
# python get_mssql_job_info.py
File "get_mssql_job_info.py", line 37
sub_cursor =db_sub_conn.cursor(as_dict=True)
^
IndentationError: unexpected indent
结果也是发现注释也必须和代码对齐
正确的对齐方式如下:
虽然是一个小小的问题,还是折射出对Python代码对齐理解的一些细节问题的疏忽。

· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
2014-07-14 管理故事——和尚挑水的故事
2014-07-14 ORACLE优化器RBO与CBO介绍总结