Jupyter 노트북에서 목록을 테이블로 출력하려면 어떻게해야합니까?
나는 전에 어딘가에서 몇 가지 예를 보았지만 내 삶을 위해 인터넷 검색을 할 때 찾을 수 없다는 것을 알고 있습니다.
데이터 행이 있습니다.
data = [[1,2,3],
[4,5,6],
[7,8,9],
]
이 데이터를 테이블에 출력하고 싶습니다.
+---+---+---+
| 1 | 2 | 3 |
+---+---+---+
| 4 | 5 | 6 |
+---+---+---+
| 7 | 8 | 9 |
+---+---+---+
분명히 나는 prettytable과 같은 라이브러리를 사용하거나 pandas 등을 다운로드 할 수 있지만 그렇게하는 데는 무관심합니다.
내 행을 Jupyter 노트북 셀의 테이블로 출력하고 싶습니다. 어떻게해야합니까?
방금 tabulate 에 HTML 옵션이 있고 사용하기가 다소 간단 하다는 것을 발견했습니다 .
Wayne Werner의 답변과 매우 유사합니다.
from IPython.display import HTML, display
import tabulate
table = [["Sun",696000,1989100000],
["Earth",6371,5973.6],
["Moon",1737,73.5],
["Mars",3390,641.85]]
display(HTML(tabulate.tabulate(table, tablefmt='html')))
셀을 병합하고 노트북에서 변수 대체를 수행하기 위해 라텍스 구문 및 서식과 같이 더 복잡한 테이블 레이아웃을 만드는 데 사용하기 쉬운 방법을 찾고 있습니다.
마크 다운 셀에서 Python 변수에 대한 참조 허용 # 2958
마침내 찾고 있던 jupyter / IPython 문서 를 다시 찾았습니다 .
나는 이것이 필요했다 :
from IPython.display import HTML, display
data = [[1,2,3],
[4,5,6],
[7,8,9],
]
display(HTML(
'<table><tr>{}</tr></table>'.format(
'</tr><tr>'.join(
'<td>{}</td>'.format('</td><td>'.join(str(_) for _ in row)) for row in data)
)
))
(나는 약간의 이해를 망쳐 놓았을지 모르지만 display(HTML('some html here'))
우리가 필요했던 것입니다)
멋진 트릭이 있습니다. 데이터를 pandas DataFrame으로 래핑합니다.
import pandas as pd
data = [[1, 2], [3, 4]]
pd.DataFrame(data, columns=["Foo", "Bar"])
다음과 같은 데이터를 표시합니다.
| Foo | Bar |
0 | 1 | 2 |
1 | 3 | 4 |
표 텍스트가 잘 맞습니다.
import tabletext
data = [[1,2,30],
[4,23125,6],
[7,8,999],
]
print tabletext.to_text(data)
결과:
┌───┬───────┬─────┐
│ 1 │ 2 │ 30 │
├───┼───────┼─────┤
│ 4 │ 23125 │ 6 │
├───┼───────┼─────┤
│ 7 │ 8 │ 999 │
└───┴───────┴─────┘
다음 기능을 사용해 볼 수 있습니다.
def tableIt(data):
for lin in data:
print("+---"*len(lin)+"+")
for inlin in lin:
print("|",str(inlin),"", end="")
print("|")
print("+---"*len(lin)+"+")
data = [[1,2,3,2,3],[1,2,3,2,3],[1,2,3,2,3],[1,2,3,2,3]]
tableIt(data)
좋아, 그래서 이것은 나보다 조금 더 어려웠다.
def print_matrix(list_of_list):
number_width = len(str(max([max(i) for i in list_of_list])))
cols = max(map(len, list_of_list))
output = '+'+('-'*(number_width+2)+'+')*cols + '\n'
for row in list_of_list:
for column in row:
output += '|' + ' {:^{width}d} '.format(column, width = number_width)
output+='|\n+'+('-'*(number_width+2)+'+')*cols + '\n'
return output
이것은 다양한 행, 열 및 자릿수 (숫자)에 대해 작동합니다.
data = [[1,2,30],
[4,23125,6],
[7,8,999],
]
print print_matrix(data)
>>>>+-------+-------+-------+
| 1 | 2 | 30 |
+-------+-------+-------+
| 4 | 23125 | 6 |
+-------+-------+-------+
| 7 | 8 | 999 |
+-------+-------+-------+
모든 파이썬 데이터 구조 (함께 중첩 된 사전 및 목록)를 HTML로 렌더링하는 범용 함수 세트입니다.
from IPython.display import HTML, display
def _render_list_html(l):
o = []
for e in l:
o.append('<li>%s</li>' % _render_as_html(e))
return '<ol>%s</ol>' % ''.join(o)
def _render_dict_html(d):
o = []
for k, v in d.items():
o.append('<tr><td>%s</td><td>%s</td></tr>' % (str(k), _render_as_html(v)))
return '<table>%s</table>' % ''.join(o)
def _render_as_html(e):
o = []
if isinstance(e, list):
o.append(_render_list_html(e))
elif isinstance(e, dict):
o.append(_render_dict_html(e))
else:
o.append(str(e))
return '<html><body>%s</body></html>' % ''.join(o)
def render_as_html(e):
display(HTML(_render_as_html(e)))
나는 같은 문제가 있었다. 나는 나를 도울 수있는 것을 찾을 수 없었기 때문에 결국 PrintTable
아래 클래스 코드를 만들었습니다 . 출력도 있습니다. 사용법은 간단합니다.
ptobj = PrintTable(yourdata, column_captions, column_widths, text_aligns)
ptobj.print()
또는 한 줄로 :
PrintTable(yourdata, column_captions, column_widths, text_aligns).print()
산출:
-------------------------------------------------------------------------------------------------------------
Name | Column 1 | Column 2 | Column 3 | Column 4 | Column 5
-------------------------------------------------------------------------------------------------------------
Very long name 0 | 0 | 0 | 0 | 0 | 0
Very long name 1 | 1 | 2 | 3 | 4 | 5
Very long name 2 | 2 | 4 | 6 | 8 | 10
Very long name 3 | 3 | 6 | 9 | 12 | 15
Very long name 4 | 4 | 8 | 12 | 16 | 20
Very long name 5 | 5 | 10 | 15 | 20 | 25
Very long name 6 | 6 | 12 | 18 | 24 | 30
Very long name 7 | 7 | 14 | 21 | 28 | 35
Very long name 8 | 8 | 16 | 24 | 32 | 40
Very long name 9 | 9 | 18 | 27 | 36 | 45
Very long name 10 | 10 | 20 | 30 | 40 | 50
Very long name 11 | 11 | 22 | 33 | 44 | 55
Very long name 12 | 12 | 24 | 36 | 48 | 60
Very long name 13 | 13 | 26 | 39 | 52 | 65
Very long name 14 | 14 | 28 | 42 | 56 | 70
Very long name 15 | 15 | 30 | 45 | 60 | 75
Very long name 16 | 16 | 32 | 48 | 64 | 80
Very long name 17 | 17 | 34 | 51 | 68 | 85
Very long name 18 | 18 | 36 | 54 | 72 | 90
Very long name 19 | 19 | 38 | 57 | 76 | 95
-------------------------------------------------------------------------------------------------------------
수업 코드 PrintTable
# -*- coding: utf-8 -*-
# Class
class PrintTable:
def __init__(self, values, captions, widths, aligns):
if not all([len(values[0]) == len(x) for x in [captions, widths, aligns]]):
raise Exception()
self._tablewidth = sum(widths) + 3*(len(captions)-1) + 4
self._values = values
self._captions = captions
self._widths = widths
self._aligns = aligns
def print(self):
self._printTable()
def _printTable(self):
formattext_head = ""
formattext_cell = ""
for i,v in enumerate(self._widths):
formattext_head += "{" + str(i) + ":<" + str(v) + "} | "
formattext_cell += "{" + str(i) + ":" + self._aligns[i] + str(v) + "} | "
formattext_head = formattext_head[:-3]
formattext_head = " " + formattext_head.strip() + " "
formattext_cell = formattext_cell[:-3]
formattext_cell = " " + formattext_cell.strip() + " "
print("-"*self._tablewidth)
print(formattext_head.format(*self._captions))
print("-"*self._tablewidth)
for w in self._values:
print(formattext_cell.format(*w))
print("-"*self._tablewidth)
데모
# Demonstration
headername = ["Column {}".format(x) for x in range(6)]
headername[0] = "Name"
data = [["Very long name {}".format(x), x, x*2, x*3, x*4, x*5] for x in range(20)]
PrintTable(data, \
headername, \
[70, 10, 10, 10, 10, 10], \
["<",">",">",">",">",">"]).print()
최근 prettytable
에 멋진 ASCII 테이블을 렌더링하는 데 사용 했습니다. postgres CLI 출력과 유사합니다.
import pandas as pd
from prettytable import PrettyTable
data = [[1,2,3],[4,5,6],[7,8,9]]
df = pd.DataFrame(data, columns=['one', 'two', 'three'])
def generate_ascii_table(df):
x = PrettyTable()
x.field_names = df.columns.tolist()
for row in df.values:
x.add_row(row)
print(x)
return x
generate_ascii_table(df)
산출:
+-----+-----+-------+
| one | two | three |
+-----+-----+-------+
| 1 | 2 | 3 |
| 4 | 5 | 6 |
| 7 | 8 | 9 |
+-----+-----+-------+
각 열이 가능한 가장 작은 너비를 갖는 테이블을 출력하고 싶습니다. 여기서 열은 공백으로 채워지고 (하지만 변경할 수 있음) 행이 줄 바꿈으로 구분되고 (하지만 변경할 수 있음), 각 항목이 str
( 그러나...).
def ftable(tbl, pad=' ', sep='\n', normalize=str):
# normalize the content to the most useful data type
strtbl = [[normalize(it) for it in row] for row in tbl]
# next, for each column we compute the maximum width needed
w = [0 for _ in tbl[0]]
for row in strtbl:
for ncol, it in enumerate(row):
w[ncol] = max(w[ncol], len(it))
# a string is built iterating on the rows and the items of `strtbl`:
# items are prepended white space to an uniform column width
# formatted items are `join`ed using `pad` (by default " ")
# eventually we join the rows using newlines and return
return sep.join(pad.join(' '*(wid-len(it))+it for wid, it in zip(w, row))
for row in strtbl)
The function signature, ftable(tbl, pad=' ', sep='\n', normalize=str)
, with its default arguments is intended to provide for maximum flexibility.
You can customize
- the column padding,
- the row separator, (e.g.,
pad='&', sep='\\\\\n'
to have the bulk of a LaTeX table) - the function to be used to normalize the input to a common string format --- by default, for the maximum generality it is
str
but if you know that all your data is floating pointlambda item: "%.4f"%item
could be a reasonable choice, etc.
Superficial testing:
I need some test data, possibly involving columns of different width so that the algorithm needs to be a little more sophisticated (but just a little bit;)
In [1]: from random import randrange
In [2]: table = [[randrange(10**randrange(10)) for i in range(5)] for j in range(3)]
In [3]: table
Out[3]:
[[974413992, 510, 0, 3114, 1],
[863242961, 0, 94924, 782, 34],
[1060993, 62, 26076, 75832, 833174]]
In [4]: print(ftable(table))
974413992 510 0 3114 1
863242961 0 94924 782 34
1060993 62 26076 75832 833174
In [5]: print(ftable(table, pad='|'))
974413992|510| 0| 3114| 1
863242961| 0|94924| 782| 34
1060993| 62|26076|75832|833174
참고URL : https://stackoverflow.com/questions/35160256/how-do-i-output-lists-as-a-table-in-jupyter-notebook
'developer tip' 카테고리의 다른 글
Go에서 파일 길이를 얻는 방법은 무엇입니까? (0) | 2020.12.10 |
---|---|
UITextField에서 자리 표시 자 텍스트의 기본 색상은 무엇입니까? (0) | 2020.12.10 |
mysql의 두 테이블 간의 차이점 비교 (0) | 2020.12.10 |
jQuery-유효성 검사 규칙을 동적으로 추가하는 방법 (0) | 2020.12.10 |
GNU autotools : 디버그 / 릴리스 타겟? (0) | 2020.12.10 |