I have the following example in Python to print a table:
job_IDs = ['13453', '123', '563456'];
memory_used = [30, 150.54, 20.6];
memory_units = ['MB', 'GB', 'MB'];
for i in range(len(job_IDs)):
print "Job {item:15} {value[0]:>6}.{value[1]:<6} {units:3}".format(
item=job_IDs[i]+':', value=memory_used[i].split('.') if '.' in memory_used[i]
else (memory_used[i], '0'), units=memory_units[i])
which results in:
Job 13453: 30 MB Job 123: 150.54 MB Job 563456: 20.6 GB
The vertical alignment is correct for what I need, but the horizontal padding is manually hard-coded in the code, where it says:
"Job {item:15} {value[0]:>6}.{value[1]:<6} {units:3}"
(the "padding parameters" above are 15, 6, 6, 3
)
I would like to:
Ideally, have the padding values determined automatically (i.e. computed from the maximum width of each field) instead of having to hard-code them in the statement above.
In the example above, it would be great to have a snippet that uses the width of the widest entries in
job_IDs
,memory_used
, andmemory_units
and outputs, leaving one space between columns:Job 13453: 30 MB Job 123: 150.54 MB Job 563456: 20.6 GB
Alternatively, I would also interested in a solution that allows me to specify such paddings in variables (in case I want to control the width given to each column).
I am interested in solutions for both problems: with the padding computed automatically, and with the padding specified with variables.
By the way, This question was inspired by this other question: Using Python's Format Specification Mini-Language to align floats