0

我想要以下代码:

Tier0 = ['Tier', 'Weights', 'Price', 'Number of Businesses', 'Revenue']
Tier1 = ['Tier 1', 180,]
Tier2 = ['Tier 2', 300,]
Tier3 = ['Tier 3', 450,]
Tier4 = ['Tier 4', 600,]
Tier5 = ['Tier 5', 750,]

data = []
data.append(Tier0)
data.append(Tier1)
data.append(Tier2)
data.append(Tier3)
data.append(Tier4)
data.append(Tier5)    
data

for Tier1 in data[1:]: 
    Tier1.insert(1, float(input('Enter the weighted value of Tiers 1-5 as a decimal: ')))
    Tier1.insert(3, Tier1[1] * MissouriBusiness)#calculates the number of businesses
    Tier1.insert(4, Tier1[2] * Tier1[1] * MissouriBusiness)#calculates the revenue

要更改的输出:

[['Tier', 'Weights', 'Price', 'Number of Businesses', 'Revenue'], ['Tier 1', 0.2, 180, 40000.0, 7200000.0], ['Tier 2', 0.1, 300, 20000.0, 6000000.0], ['Tier 3', 0.3, 450, 60000.0, 27000000.0], ['Tier 4', 0.15, 600, 30000.0, 18000000.0], ['Tier 5', 0.2, 750, 40000.0, 30000000.0]]

更好的东西,比如:

[['Tier', 'Weights', 'Price', 'Number of Businesses', 'Revenue'], 
['Tier 1', 0.2, 180, 14000.0, 2520000.0], 
['Tier2', 0.2, 300, 14000.0, 4200000.0], 
['Tier3', 0.2, 450, 14000.0, 6300000.0], 
['Tier4', 0.3, 600, 21000.0, 12600000.0], 
['Tier5', 0.1, 750, 7000.0, 5250000.0]] 

Python 文档有一个很好的例子,我似乎无法理解它是如何工作的。

>>> for x in range(1, 11):
...     print repr(x).rjust(2), repr(x*x).rjust(3),
...     # Note trailing comma on previous line
...     print repr(x*x*x).rjust(4)
...
 1   1    1
 2   4    8
 3   9   27
 4  16   64
 5  25  125

此代码来自 Python 的文档:https ://docs.python.org/2/tutorial/inputoutput.html

非常感谢您对此repr函数的工作原理以及如何合并它的简单解释,因为我在查看文档或其他类似问题时只会看到胡言乱语。

TIA

4

1 回答 1

0

repr函数旨在返回“可打印的对象表示”,可能与该eval函数一起使用以从其字符串表示构造回对象。但repr它本身不做任何格式化,它只是调用__repr__对象上的方法,这可能是一些默认的 Python 实现或您对对象的实现。

在您的情况下,当您调用repr列表时,它只返回带引号的列表输出,因为这repr就是列表对象的实现方式:

>>> data = [['Tier', 'Weights', 'Price', 'Number of Businesses', 'Revenue'], ['Tier 1', 0.2, 180, 40000.0, 7200000.0], ['Tier 2', 0.1, 300, 20000.0, 6000000.0], ['Tier 3', 0.3, 450, 60000.0, 27000000.0], ['Tier 4', 0.15, 600, 30000.0, 18000000.0], ['Tier 5', 0.2, 750, 40000.0, 30000000.0]]
>>> repr(data)
"[['Tier', 'Weights', 'Price', 'Number of Businesses', 'Revenue'], ['Tier 1', 0.2, 180, 40000.0, 7200000.0], ['Tier 2', 0.1, 300, 20000.0, 6000000.0], ['Tier 3', 0.3, 450, 60000.0, 27000000.0], ['Tier 4', 0.15, 600, 30000.0, 18000000.0], ['Tier 5', 0.2, 750, 40000.0, 30000000.0]]"

您提供的repr示例实际上只不过是手动格式化。repr在这种情况下,仅用于获取整数的字符串表示形式,x以便能够对其调用string.rjust格式化函数:

>>> repr(1)
'1'
>>> repr(1).rjust(3)
'  1'

至于您的情况,您可以使用pprint用于 Python 数据结构漂亮打印的模块。该pprint.pprint函数实际上的行为几乎完全符合您的要求:

>>> data = [['Tier', 'Weights', 'Price', 'Number of Businesses', 'Revenue'], ['Tier 1', 0.2, 180, 40000.0, 7200000.0], ['Tier 2', 0.1, 300, 20000.0, 6000000.0], ['Tier 3', 0.3, 450, 60000.0, 27000000.0], ['Tier 4', 0.15, 600, 30000.0, 18000000.0], ['Tier 5', 0.2, 750, 40000.0, 30000000.0]]
>>> import pprint
>>> pprint.pprint(data)
[['Tier', 'Weights', 'Price', 'Number of Businesses', 'Revenue'],
 ['Tier 1', 0.2, 180, 40000.0, 7200000.0],
 ['Tier 2', 0.1, 300, 20000.0, 6000000.0],
 ['Tier 3', 0.3, 450, 60000.0, 27000000.0],
 ['Tier 4', 0.15, 600, 30000.0, 18000000.0],
 ['Tier 5', 0.2, 750, 40000.0, 30000000.0]]

但是如果你需要一些非常具体的东西,你可能需要自己打印。

于 2014-06-22T06:22:05.003 回答