2

ラベルのリストとデータは次のとおりです。

['id'、'Version'、'chip_name'、'xversion'、'device'、'opt_param'、'place_effort']
[1、1.0、u'virtex2'、u'xilinx11.5'、u'xc5vlx50'、u'Speed'、u'High']

それらをコンソールに印刷する必要があります。このために、リストを繰り返し処理し、タブ('\ t')を使用して各要素を出力します。

しかし、残念ながら、結果はそれほどきれいではありません。

データ1の数と列7の数
idバージョンchip_namexversionデバイスopt_paramplace_effort        
1 1.0 virtex2xilinx11.5xc5vlx50高速高速        

ラベルとデータの文字列の長さは非常に可変であり、適切に配置されていません。

Pythonでこの問題の解決策はありますか?

追加した

Mike DeSimoneの答えに喜んで、私は自分の目的に使用できるきれいなプリンターを作ることができました。valueResultsは重複のリストです。

    labels = queryResult.names
    valueResults = queryResult.result

    # get the maximum width
    allData = valueResults
    allData.insert(0,labels)
    transpose = zip(*valueResults) # remove the sequence as a parameter
    #print transpose
    for value in transpose:
        # value is integer/float/unicode/str, so make it length of str
        newValue = [len(str(i)) for i in value]
        columnWidth = max(newValue)
        columnWidths.append(columnWidth)
        dividers.append('-' * columnWidth)
        dblDividers.append('=' * columnWidth)
        label = value[0]
        paddedLabels.append(label.center(columnWidth))

    paddedString = ""

    for values in valueResults[1:]:
        paddedValue = []
        for i, value in enumerate(values):
            svalue = str(value)
            columnWidth = columnWidths[i]
            paddedValue.append(svalue.center(columnWidth))
        paddedString += '| ' + ' | '.join(paddedValue) + ' |' + '\n'

    string += '+-' + '-+-'.join(dividers) + '-+' + '\n'
    string += '| ' + ' | '.join(paddedLabels) + ' |' + '\n'
    string += '+=' + '=+='.join(dblDividers) + '=+' + '\n'
    string += paddedString
    string += '+-' + '-+-'.join(dividers) + '-+' + '\n'

そしてこれが結果です。

+ ---- + --------- + ----------- + ------------ + --------- -+ ----------- + -------------- +
| id | バージョン| chip_name | xversion | デバイス| opt_param | place_effort |
+ ==== + ========= + =========== + ============ + ========= = + =========== + ============== +
| 1 | 1.0 | virtex2 | xilinx11.5 | xc5vlx50 | スピード| 高|
| 2 | 1.0 | virtex2 | xilinx11.5 | xc5vlx50 | スピード| 高|
+ ---- + --------- + ----------- + ------------ + --------- -+ ----------- + -------------- +

助けてくれてありがとう。

4

6 に答える 6

4

印刷する前に、ljustを使用して内容を詰め込みます。

import sys

def maxwidth(table, index):
    """Get the maximum width of the given column index"""
    return max([len(str(row[index])) for row in table])

def pprint_table(table):
    colpad = []

    for i in range(len(table[0])):
        colpad.append(maxwidth(table, i))

    for row in table:
        print str(row[0]).ljust(colpad[0] + 1),
        for i in range(1, len(row)):
            col = str(row[i]).rjust(colpad[i] + 2)
            print "", col,
        print ""

a = ['id', 'Version', 'chip_name', 'xversion', 'device', 'opt_param', 'place_effort']
b = [1, 1.0, u'virtex2', u'xilinx11.5', u'xc5vlx50', u'Speed', u'High']

# Put it in the table

c = [a, b]

pprint_table(c)

出力:

id     Version    chip_name      xversion      device    opt_param    place_effort 
1          1.0      virtex2    xilinx11.5    xc5vlx50        Speed            High
于 2010-09-13T04:21:23.790 に答える
3

このようなもの:

labels = ['id', 'Version', 'chip_name', 'xversion', 'device', 'opt_param', 
    'place_effort']
values = [1, 1.0, u'virtex2', u'xilinx11.5', u'xc5vlx50', u'Speed', u'High']

paddedLabels = []
paddedValues = []

for label, value in zip(labels, values):
    value = str(value)
    columnWidth = max(len(label), len(value))
    paddedLabels.append(label.center(columnWidth))
    paddedValues.append(value.center(columnWidth))

print ' '.join(paddedLabels)
print ' '.join(paddedValues)

出力:

id Version chip_name  xversion   device  opt_param place_effort
1    1.0    virtex2  xilinx11.5 xc5vlx50   Speed       High

ファンシーになりたい場合は、reStructuredText対応にします。

labels = ['id', 'Version', 'chip_name', 'xversion', 'device', 'opt_param', 
    'place_effort']
values = [1, 1.0, u'virtex2', u'xilinx11.5', u'xc5vlx50', u'Speed', u'High']

paddedLabels = []
paddedValues = []
dividers = []
dblDividers = []

for label, value in zip(labels, values):
    value = str(value)
    columnWidth = max(len(label), len(value))
    paddedLabels.append(label.center(columnWidth))
    paddedValues.append(value.center(columnWidth))
    dividers.append('-' * columnWidth)
    dblDividers.append('=' * columnWidth)

print '+-' + '-+-'.join(dividers) + '-+'
print '| ' + ' | '.join(paddedLabels) + ' |'
print '+=' + '=+='.join(dblDividers) + '=+'
print '| ' + ' | '.join(paddedValues) + ' |'
print '+-' + '-+-'.join(dividers) + '-+'

出力:

+----+---------+-----------+------------+----------+-----------+--------------+
| id | Version | chip_name |  xversion  |  device  | opt_param | place_effort |
+====+=========+===========+============+==========+===========+==============+
| 1  |   1.0   |  virtex2  | xilinx11.5 | xc5vlx50 |   Speed   |     High     |
+----+---------+-----------+------------+----------+-----------+--------------+
于 2010-09-13T04:12:40.970 に答える
3

あなたはこれを試すことができます

>>> table = {'Sjoerd': 4127, 'Jack': 4098, 'Dcab': 7678}
>>> for name, phone in table.items():
...     print '{0:10} ==> {1:10d}'.format(name, phone)
...
Jack       ==>       4098
Dcab       ==>       7678
Sjoerd     ==>       4127

http://docs.python.org/tutorial/inputoutput.htmlから

後の整数: はパディングです。

またはそれ以上

>>> table = {'Sjoerd': 4127, 'Jack': 4098, 'Dcab': 8637678}
>>> print ('Jack: {0[Jack]:d}; Sjoerd: {0[Sjoerd]:d}; '
...        'Dcab: {0[Dcab]:d}'.format(table))
Jack: 4098; Sjoerd: 4127; Dcab: 8637678
于 2010-09-13T04:46:38.917 に答える
2

すぐに使えるソリューションを使用できます:: prettytable視覚的に魅力的なASCIIテーブル形式で表形式のデータを簡単に表示するためのシンプルなPythonライブラリ

他の解決策、私の同様の質問を参照してください他の答え:きれいな印刷モジュールをテーブルに拡張する方法は?

于 2010-09-13T04:59:55.510 に答える
1

もう1つの解決策は、タブをまったく使用せず、スペースを使用して列幅を調整することです。また、「%Ns」文字列の書式設定が便利なため、手動でパディングする必要もありません。

header = ['id', 'Version', 'chip_name', 'xversion', 'device', 'opt_param', 'place_effort']
rows = [[1, 1.0, u'virtex2', u'xilinx11.5', u'xc5vlx50', u'Speed', u'High']]

def print_row(row):
    column_width=12
    format_str = ("%-"+str(column_width)+"s")*len(row)
    print format_str%tuple(row)

print_row(header)
for row in rows:
    print_row(row)

出力:

id          Version     chip_name   xversion    device      opt_param   place_effort
1           1.0         virtex2     xilinx11.5  xc5vlx50    Speed       High
于 2010-09-13T04:41:11.313 に答える
0

簡単な解決策として、lnがこれらすべてのリストを含むリストである場合、

for l in ln:
    print "\t".join([str(x).ljust(10) for x in l])

タブで区切られ、左寄せされた列を印刷します。まだきれいでない場合は、ljust内の値を増やします。

于 2010-09-13T09:36:48.773 に答える