如何在运行Python代码时从Pylint获得Report+分数?

2024-08-11Python开发问题
2

本文介绍了如何在运行Python代码时从Pylint获得Report+分数?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

直接从Python代码运行pylint时,似乎无法获得任何返回值。从命令行运行它会生成一个很好的报告,底部会显示汇总分数。

我尝试将"run"的返回值放入一个变量,并将其放入"Reports"字段-但它看起来像某个默认模板。

这是我拥有的:

from io import StringIO
from pylint.reporters import text
from pylint.lint import Run


def main():
    print("I will verify you build!")
    pylint_opts = ['--rcfile=pylintrc.txt', '--reports=n', 'utilities']
    pylint_output = StringIO()
    reporter = text.TextReporter(pylint_output)
    Run(pylint_opts, reporter=reporter, do_exit=False)
    print(pylint_output.read())


if __name__ == '__main__':
    main()

我希望这里会有一些报告,但我得到的都是: " 我将验证您的版本!

进程已完成,退出代码为0 "

推荐答案

我调查了pylint问题。我们最终保留了当前行为,因为您的代码只需稍作调整即可工作:

def main():
    print("I will verify you build!")
    pylint_opts = ['--rcfile=pylintrc.txt', '--reports=n', 'utilities']
    pylint_output = StringIO()
    reporter = text.TextReporter(pylint_output)
    Run(pylint_opts, reporter=reporter, do_exit=False)
    print(pylint_output.getvalue())

StringIO是不隐藏流位置的流。Pylint正确写入pylint_output,但将光标留在流的末尾。pylint_output.read()仅从游标开始读取。

您可以先调用pylint_output.seek(0)重置流位置,然后再调用pylint_output.read()。或者,如上面的代码挡路所示,StringIO提供了一个方法getvalue,该方法将返回缓冲区的全部内容,而不考虑光标的位置。

Pylint文档将使用此示例进行更新,因此感谢您提出此问题。

这篇关于如何在运行Python代码时从Pylint获得Report+分数?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

在xarray中按单个维度的多个坐标分组
groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)...
2024-08-22 Python开发问题
15

Pandas中的GROUP BY AND SUM不丢失列
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)...
2024-08-22 Python开发问题
17

pandas 有从特定日期开始的按月分组的方式吗?
Is there a way of group by month in Pandas starting at specific day number?( pandas 有从特定日期开始的按月分组的方式吗?)...
2024-08-22 Python开发问题
10

GROUP BY+新列+基于条件的前一行抓取值
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)...
2024-08-22 Python开发问题
18

PANDA中的Groupby算法和插值算法
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)...
2024-08-22 Python开发问题
11

PANAS-基于列对行进行分组,并将NaN替换为非空值
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)...
2024-08-22 Python开发问题
10