编译单个语句时发现多个语句

时间:2013-09-12 18:16:54

标签: python syntax-error

我是编程的新手。我正在使用Dive into Python书,并试图运行第一个例子,humansize.py。我已经将代码复制并粘贴到Idle,即Python shell中并不断出现相同的语法错误:“编译单个语句时发现了多个语句。”

我将代码下载到BBEdit中,然后将其复制并粘贴到Idle中。我在网上看过,人们说它可能是一个标签与空间问题。但是我已经完成了代码并且看起来与本书相同,我甚至删除并重新插入了所有代码行中的4个空格,我仍然收到错误。

这令人沮丧,因为我确信这是一个简单的问题,但我已经完成了我所知道的所有事情(在尝试研究问题方面)以使其发挥作用。如果它是一个空格与制表符问题,你们中的任何人都知道我可以去哪里学习如何正确地复制和输入代码进入空闲状态的过程吗?我是一个真正的初学者。

我很感激社区的帮助。谢谢!

我正在运行Mac OSX - V.10.7.5。我正在使用最新版本的Dive to Python book和Python 3.3。

代码如下:

>>> '''Convert file sizes to human-readable form.

    Available functions:
    approximate_size(size, a_kilobyte_is_1024_bytes)
    takes a file size and returns a human-readable string

Examples:
>>> approximate_size(1024)
    '1.0 KiB'
>>> approximate_size(1000, False)
    '1.0 KB'

    '''

    SUFFIXES = {1000: ['KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'],
            1024: ['KiB', 'MiB', 'GiB', 'TiB', 'PiB', 'EiB', 'ZiB', 'YiB']}

    def approximate_size(size, a_kilobyte_is_1024_bytes=True):
    '''Convert a file size to human-readable form.

    Keyword arguments:
    size -- file size in bytes
    a_kilobyte_is_1024_bytes -- if True (default), use multiples of 1024
                                if False, use multiples of 1000

    Returns: string

    '''
    if size < 0:
        raise ValueError('number must be non-negative')

    multiple = 1024 if a_kilobyte_is_1024_bytes else 1000
    for suffix in SUFFIXES[multiple]:
        size /= multiple
        if size < multiple:
            return '{0:.1f} {1}'.format(size, suffix)

    raise ValueError('number too large')

    if __name__ == '__main__':
    print(approximate_size(1000000000000, False))
    print(approximate_size(1000000000000))

**SyntaxError: multiple statements found while compiling a single statement**
>>> 

1 个答案:

答案 0 :(得分:1)

你有一些缩进问题。在python中缩进非常重要,因为解释器使用缩进级别来决定如何对语句进行分组。例如:

if (False):
    print("Hello")
print("World")

永远不应该运行与if(False)语句分组的语句,因为if(False)永远不应该为true。但我给你的例子仍然会输出“世界”。这是因为解释器不会将第二个print语句视为if语句的一部分。现在,如果我采用完全相同的代码并缩进第二个打印语句,如下所示:

if (False):
    print("Hello")
    print("World")

解释器将看到两个打印语句都是比if语句更深的缩进级别,并且不会输出任何内容,因为if(False)始终为false。

相同的缩进适用于函数定义。例如:

def foo():
    if(True):
        print("Hello, World")

因为if语句缩进了一个级别,foo的定义与foo函数分组。因此,当您调用foo函数时,它将输出“Hello,World”。

现在是变量。在您的代码中,您将变量缩进到一个级别。如果它是函数定义的一部分,if语句,for循环等,哪个会好的。但是因为它不是,它会产生问题。以下面的例子为例:

    a="Hello, World"

if(True):
    print(a)

会给你一个语法或缩进错误,而:

a="Hello, World"

if(True):
    print(a)

将打印“Hello,World”。

现在关注您的代码:

   SUFFIXES = {1000: ['KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'],
        1024: ['KiB', 'MiB', 'GiB', 'TiB', 'PiB', 'EiB', 'ZiB', 'YiB']}

需要取消缩进一级才能成为:

SUFFIXES = {1000: ['KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'],
        1024: ['KiB', 'MiB', 'GiB', 'TiB', 'PiB', 'EiB', 'ZiB', 'YiB']}

此外:

    def approximate_size(size, a_kilobyte_is_1024_bytes=True):

需要取消缩进一级才能成为:

def approximate_size(size, a_kilobyte_is_1024_bytes=True):

if __name__ == '__main__':
print(approximate_size(1000000000000, False))
print(approximate_size(1000000000000))

需要:

if __name__ == '__main__':
    print(approximate_size(1000000000000, False))
    print(approximate_size(1000000000000))

将所有这些放在一起,你得到:

SUFFIXES = {1000: ['KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'],
        1024: ['KiB', 'MiB', 'GiB', 'TiB', 'PiB', 'EiB', 'ZiB', 'YiB']}

def approximate_size(size, a_kilobyte_is_1024_bytes=True):
    '''Convert a file size to human-readable form.

    Keyword arguments:
    size -- file size in bytes    
    a_kilobyte_is_1024_bytes -- if True (default), use multiples of 1024
                            if False, use multiples of 1000

    Returns: string

    '''
    if size < 0:
        raise ValueError('number must be non-negative')

    multiple = 1024 if a_kilobyte_is_1024_bytes else 1000
    for suffix in SUFFIXES[multiple]:
        size /= multiple
        if size < multiple:
            return '{0:.1f} {1}'.format(size, suffix)

    raise ValueError('number too large')

if __name__ == '__main__':
    print(approximate_size(1000000000000, False))
    print(approximate_size(1000000000000))

我希望这有帮助!