错误类型:强制转换为Unicode,需要字符串或缓冲区,找到NoneType

2024-05-23 14:20:35 发布

您现在位置:Python中文网/ 问答频道 /正文

目前为一个程序和一个组件编写一个函数是为了搜索一个python文件中是否使用了单个变量。

功能:

def SINGLE_CHAR_VAR(python_filename):
    file = open(python_filename)
    lines = [0]
    SINGLE_CHAR_VAR = []
    for line in file:
        stripped = line.strip('\n\r')
        lines.append(stripped)

    from utils import vars_indents
    variable_list = (vars_indents(python_filename))[0]
    for i in range(1, len(variable_list)):
        if len(variable_list[i][0][0]) == 1:
            SINGLE_CHAR_VAR.append(['SINGLE_CHAR_VAR', i, variable_list[i][0][1], variable_list[i][0][0], lines[i]])      
    return SINGLE_CHAR_VAR​

当我单独使用这个函数时-函数工作正常。 但是,当我作为一个整体调用程序时,会收到以下错误消息:

Traceback (most recent call last):
  File "<web session>", line 1, in <module>
  File "lint_2.py", line 141, in lint
    sorted_error_list = sorted_list(list_of_file_errors)
  File "lint_2.py", line 84, in sorted_list
    error_list = total_error_list(python_filename)
  File "lint_2.py", line 65, in total_error_list
    single_char_var_list = SINGLE_CHAR_VAR(python_filename)
  File "lint_2.py", line 33, in SINGLE_CHAR_VAR
    file = open(python_filename)
TypeError: coercing to Unicode: need string or buffer, NoneType found

我完全不知道-我错在哪里-任何帮助都是非常,非常,非常珍惜的!!!

谢谢。


Tags: 函数inpyvarlineerrorfilenamevariable