자르지 않고 전체 NumPy 배열을 인쇄하는 방법은 무엇입니까?


589

numpy 배열을 인쇄하면 잘린 표현이 표시되지만 전체 배열을 원합니다.

이것을 할 수있는 방법이 있습니까?

예 :

>>> numpy.arange(10000)
array([   0,    1,    2, ..., 9997, 9998, 9999])

>>> numpy.arange(10000).reshape(250,40)
array([[   0,    1,    2, ...,   37,   38,   39],
       [  40,   41,   42, ...,   77,   78,   79],
       [  80,   81,   82, ...,  117,  118,  119],
       ..., 
       [9880, 9881, 9882, ..., 9917, 9918, 9919],
       [9920, 9921, 9922, ..., 9957, 9958, 9959],
       [9960, 9961, 9962, ..., 9997, 9998, 9999]])

18
"일회성"으로 할 수있는 방법이 있습니까? 즉, 전체 출력을 한 번 인쇄하지만 다른 시간에는 스크립트에서 인쇄하지 않습니까?
tumultous_rooster

4
@Matt O'Brien은 ZSG의 답변을 아래에서 참조하십시오
user2398029

6
수락 한 답변을 추천 답변으로 변경할 수 np.inf있습니까? np.nan'nan'단지 총 우연에 의해 작업, 그리고 'nan'파이썬 3도 일을하지 않는 그들이 혼합 유형 비교 구현 변경 되었기 때문에 threshold='nan'에 의존합니다.
user2357112는

1
( threshold=np.nan대신이 'nan'배열 인쇄 논리와 임계 값에 배열 크기를 비교한다는 것입니다 다른 우연에 따라 달라집니다 a.size > _summaryThreshold.이 항상 수익을 False위해 _summaryThreshold=np.nan. 비교가 있었다면 a.size <= _summaryThreshold, 배열이 완전히 대신 테스트의 인쇄 여부를 테스트는해야하는지 여부 요약하면,이 임계 값은 모든 어레이에 대한 요약을 트리거합니다.)
user2357112는 Monica

4
A "일회성"그것을하는 방법 : 당신이 numpy.array이있는 경우 tmp단지 list(tmp). 다른 형식의 다른 옵션은 tmp.tolist()또는 더 많은 제어를위한 것 print("\n".join(str(x) for x in tmp))입니다.
travc

답변:


629

사용 numpy.set_printoptions:

import sys
import numpy
numpy.set_printoptions(threshold=sys.maxsize)

2
numpy어레이를 한 번만 인쇄하려는 경우 불행히도이 솔루션에는 인쇄 후 구성 변경을 재설정해야하는 단점이 있습니다.
Trevor Boyd Smith

1
@TrevorBoydSmith, 인쇄 후이 매개 변수를 재설정하는 방법을 알고 있습니까?
ColinMac

1
@ColinMac은 stackoverflow.com/a/24542498/52074 에서 설정을 저장합니다. 작업을 수행합니다. 그런 다음 설정을 복원합니다.
Trevor Boyd Smith

1
어떻게 다시 정상으로 재설정합니까?
Gulzar

임계 값 크기를 수동으로 입력하는 방법이 있습니까?
Amar Kumar

226
import numpy as np
np.set_printoptions(threshold=np.inf)

나는 다른 사람들이 제안하는 np.inf대신에 사용 하는 것이 좋습니다 np.nan. 둘 다 목적에 맞게 작동하지만 임계 값을 "무한"으로 설정하면 코드를 읽는 모든 사람이 의미하는 바를 알 수 있습니다. "숫자가 아님"의 임계 값을 갖는 것은 조금 모호한 것 같습니다.


15
이것의 역동 작은 무엇입니까? 이전 설정으로 돌아가는 방법 (도트 포함)?
Karlo

9
@Karlo 기본 숫자는 1000이므로 np.set_printoptions(threshold=1000)기본 동작으로 되돌립니다. 그러나이 임계 값을 원하는만큼 낮게 또는 높게 설정할 수 있습니다. np.set_printoptions(threshold=np.inf)인쇄 배열이 무한대로 잘 리기 전에 가능한 최대 크기 만 변경하면 아무리 커도 잘리지 않습니다. 임계 값을 실수로 설정하면 최대 크기가됩니다.
PaulMag

8
이것은 더 명확 할뿐만 아니라 훨씬 덜 취약합니다. 없다 처리 특별한 을 위해 np.inf, np.nan또는이 'nan'. 거기에 무엇이든간에 NumPy는 여전히 평문 >을 사용 하여 배열의 크기를 임계 값과 비교합니다. np.nan이 때문에 단지 사업에 일어나는 a.size > _summaryThreshold대신 a.size <= _summaryThreshold, 및 np.nan반환 False모든 >/ </ >=/ <=비교. 'nan'Python 2의 혼합 유형 비교 논리에 대한 취약한 구현 세부 사항으로 인해 작동합니다. 그것은 파이썬 3에서 완전히 깨집니다.
user2357112는 Monica

2
값이 int로 문서화되었으므로 sys.maxsize를 사용하십시오.
mattip

2
@Karlo의 질문에 올바르게 대답하려면 인쇄 옵션 임계 값의 초기 값은에 있습니다 np.get_printoptions()['threshold']. 임계 값을 설정하기 전에이 값을 저장 한 다음 나중에 복원 할 수 있습니다 (또는 with다른 답변에서 제안한대로 블록을 사용 ).
Ninjakannon

94

이전 답변은 정답이지만 약한 대안으로 목록으로 변환 할 수 있습니다.

>>> numpy.arange(100).reshape(25,4).tolist()

[[0, 1, 2, 3], [4, 5, 6, 7], [8, 9, 10, 11], [12, 13, 14, 15], [16, 17, 18, 19], [20, 21,
22, 23], [24, 25, 26, 27], [28, 29, 30, 31], [32, 33, 34, 35], [36, 37, 38, 39], [40, 41,
42, 43], [44, 45, 46, 47], [48, 49, 50, 51], [52, 53, 54, 55], [56, 57, 58, 59], [60, 61,
62, 63], [64, 65, 66, 67], [68, 69, 70, 71], [72, 73, 74, 75], [76, 77, 78, 79], [80, 81,
82, 83], [84, 85, 86, 87], [88, 89, 90, 91], [92, 93, 94, 95], [96, 97, 98, 99]]

14
이것은 인쇄 문에서 전체 배열을 보는 가장 좋은 일회성 방법 인 것 같습니다.
Aaron Bramson '

@AaronBramson 동의합니다 ... 단 하나의 인쇄 명령문 (구성 변경, 인쇄, 재설정 구성의 경우 3 줄이 아닌 한 줄의 코드)이 필요할 때 오류가 덜 발생합니다.
Trevor Boyd Smith

나는 이것이 쉼표 구분 기호를 인쇄하는 것을 좋아한다
ObviousChild

57

NumPy 1.15 이상

NumPy 1.15 (2018-07-23 릴리스) 이상을 사용하는 경우 printoptions컨텍스트 관리자를 사용할 수 있습니다 .

with numpy.printoptions(threshold=numpy.inf):
    print(arr)

(물론, 교체 numpynp가져온 어떻게 인 경우에 numpy)

컨텍스트 관리자 ( with-block)를 사용하면 컨텍스트 관리자가 완료된 후 인쇄 옵션이 블록이 시작되기 전의 상태로 되돌아갑니다. 설정이 일시적이며 블록 내의 코드에만 적용됩니다.

컨텍스트 관리자 및 기타 지원되는 인수에 대한 자세한 내용 은 numpy.printoptions설명서 를 참조하십시오 .


41

numpy를 사용하는 것처럼 들립니다.

이 경우 다음을 추가 할 수 있습니다.

import numpy as np
np.set_printoptions(threshold=np.nan)

코너 인쇄가 비활성화됩니다. 자세한 내용은이 NumPy 자습서를 참조하십시오 .


4
ValueError: threshold must be numeric and non-NAN, try sys.maxsize for untruncated representation
Eric

네, 공식 Numpy 튜토리얼의 해당 부분이 잘못되었습니다
aderchox

36

이 작업을 수행하는 일회용 방법은 다음과 같습니다. 기본 설정을 변경하지 않으려는 경우에 유용합니다.

def fullprint(*args, **kwargs):
  from pprint import pprint
  import numpy
  opt = numpy.get_printoptions()
  numpy.set_printoptions(threshold=numpy.inf)
  pprint(*args, **kwargs)
  numpy.set_printoptions(**opt)

13
이것이 컨텍스트 관리자를 사용하기에 좋은 장소 인 것 같습니다. "fullprint로"라고 말할 수 있습니다.
Paul 가격

8
사용하지 마십시오 'nan', np.nan또는 위의. 그것은 지원되지 않으며,이 나쁜 조언은 사람들이 파이썬 3으로 전환하는 데 고통을줍니다.
Eric

1
과 5 호선을 교체 @ZSGnumpy.set_printoptions(threshold=numpy.inf)
NIRMAL

@Nirmal에게 감사드립니다.이 2014 답변을 편집하여 오늘 작동합니다.
Paul Rougieux

31

Paul Price가 제안한 대로 컨텍스트 관리자 사용

import numpy as np


class fullprint:
    'context manager for printing full numpy arrays'

    def __init__(self, **kwargs):
        kwargs.setdefault('threshold', np.inf)
        self.opt = kwargs

    def __enter__(self):
        self._opt = np.get_printoptions()
        np.set_printoptions(**self.opt)

    def __exit__(self, type, value, traceback):
        np.set_printoptions(**self._opt)


if __name__ == '__main__': 
    a = np.arange(1001)

    with fullprint():
        print(a)

    print(a)

    with fullprint(threshold=None, edgeitems=10):
        print(a)

7
이 컨텍스트 매니저는 NumPy와 1.15에 덕분에 내장되어 github.com/numpy/numpy/pull/10406을 이름으로,np.printoptions
에릭

13

numpy.savetxt

numpy.savetxt(sys.stdout, numpy.arange(10000))

또는 문자열이 필요한 경우 :

import StringIO
sio = StringIO.StringIO()
numpy.savetxt(sio, numpy.arange(10000))
s = sio.getvalue()
print s

기본 출력 형식은 다음과 같습니다.

0.000000000000000000e+00
1.000000000000000000e+00
2.000000000000000000e+00
3.000000000000000000e+00
...

추가 인수로 구성 할 수 있습니다.

특히 대괄호를 표시하지 않는 방법에 유의하십시오. 대괄호 없이 Numpy 배열을 인쇄하는 방법은 무엇입니까?

Python 2.7.12, numpy 1.11.1에서 테스트되었습니다.


1
이 방법의 단점은 1d 및 2d 배열에서만 작동한다는 것입니다.
Fnord

이 정보에 대한 @Fnord 감사합니다. 해결 방법을 찾으면 알려주십시오!
Ciro Santilli 郝海东 冠状 病 六四 事件 法轮功

10

이것은 약간의 수정 (제거에 추가 인수를 전달하는 옵션 set_printoptions)neok 의 대답.

contextlib.contextmanager적은 코드 줄로 이러한 컨텍스트 관리자를 쉽게 만드는 방법을 보여줍니다 .

import numpy as np
from contextlib import contextmanager

@contextmanager
def show_complete_array():
    oldoptions = np.get_printoptions()
    np.set_printoptions(threshold=np.inf)
    try:
        yield
    finally:
        np.set_printoptions(**oldoptions)

코드에서 다음과 같이 사용할 수 있습니다.

a = np.arange(1001)

print(a)      # shows the truncated array

with show_complete_array():
    print(a)  # shows the complete array

print(a)      # shows the truncated array (again)

1
당신은 항상 두어야 try/ finally주변을 yield정리는 상관없이 일어나는 그래서, 컨텍스트 매니저.
Eric

1
@Eric 실제로. 당신의 도움이 의견 주셔서 감사하고 나는 대답을 업데이트했습니다.
MSeifert

1.15에서는 철자가 가능합니다with np.printoptions(threshold=np.inf):
Eric

6

최대 열 수 (로 고정됨 ) 에서이 답변 을 보완하여 numpy.set_printoptions(threshold=numpy.nan)표시 할 문자의 제한도 있습니다. 대화식 세션이 아닌 bash에서 파이썬을 호출 할 때와 같은 일부 환경에서는 linewidth다음과 같이 매개 변수 를 설정하여이를 해결할 수 있습니다 .

import numpy as np
np.set_printoptions(linewidth=2000)    # default = 75
Mat = np.arange(20000,20150).reshape(2,75)    # 150 elements (75 columns)
print(Mat)

이 경우 창은 줄 바꿈 문자 수를 제한해야합니다.

숭고한 텍스트를 사용하고 출력 창 내에서 결과를 보려는 "word_wrap": false경우 숭고한 빌드 파일 [ source ]에 빌드 옵션 을 추가해야합니다 .



4

전원을 끄고 일반 모드로 돌아가려면

np.set_printoptions(threshold=False)

그것은 나를 위해 작동합니다 (Jupyter python 버전 3). 공식 코드에 따라 아래 코드는 기본 옵션으로 돌아갑니다. 나에게도 도움이되었습니다. > np.set_printoptions (edgeitems = 3, infstr = 'inf', linewidth = 75, nanstr = 'nan', precision = 8, suppress = False, threshold = 1000, formatter = None)
ewalel

자, Jupyter를 사용하지 않기 때문입니다. 수락 된 답변은 순수한 파이썬 환경에서 작동합니다.
Mathyou

이것은 threshold=0"가능한 빨리 자르기"를 의미합니다. 원하는 것이 아닙니다.
Eric

2

numpy 배열이 있다고 가정하십시오.

 arr = numpy.arange(10000).reshape(250,40)

np.set_printoptions를 토글하지 않고 일회용 배열로 전체 배열을 인쇄하려고하지만 컨텍스트 관리자보다 간단한 코드 (더 적은 코드)를 원한다면

for row in arr:
     print row 

2

약간의 수정 : (큰 목록을 인쇄하기 때문에)

import numpy as np
np.set_printoptions(threshold=np.inf, linewidth=200)

x = np.arange(1000)
print(x)

줄당 문자 수가 증가합니다 (기본 줄 너비는 75). 코딩 환경에 적합한 선폭에 원하는 값을 사용하십시오. 이렇게하면 줄당 더 많은 문자를 추가하여 많은 수의 출력 줄을 거치지 않아도됩니다.


1

array2string함수 문서를 사용할 수 있습니다 .

a = numpy.arange(10000).reshape(250,40)
print(numpy.array2string(a, threshold=numpy.nan, max_line_width=numpy.nan))
# [Big output]

ValueError: threshold must be numeric and non-NAN, try sys.maxsize for untruncated representation
Eric

1

당신은 항상 특히 큰 배열을 위해, 인쇄 된 모든 항목을 싶지 않을 것입니다.

더 많은 항목을 표시하는 간단한 방법 :

In [349]: ar
Out[349]: array([1, 1, 1, ..., 0, 0, 0])

In [350]: ar[:100]
Out[350]:
array([1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 1,
       1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1])

기본적으로 배열 <1000 썰어 때 잘 작동합니다.


0

판다를 이용할 수 있다면

    numpy.arange(10000).reshape(250,40)
    print(pandas.DataFrame(a).to_string(header=False, index=False))

재설정이 필요한 부작용을 피하고 numpy.set_printoptions(threshold=sys.maxsize)numpy.array 및 괄호를 얻지 못합니다. 넓은 배열을 로그 파일로 덤프하는 것이 편리하다는 것을 알았습니다.


-1

배열이 너무 커서 인쇄하기 어려운 경우 NumPy는 배열의 중앙 부분을 자동으로 건너 뛰고 모서리 만 인쇄합니다.이 동작을 비활성화하고 NumPy가 전체 배열을 강제로 인쇄하도록하려면을 사용하여 인쇄 옵션을 변경할 수 있습니다 set_printoptions.

>>> np.set_printoptions(threshold='nan')

또는

>>> np.set_printoptions(edgeitems=3,infstr='inf',
... linewidth=75, nanstr='nan', precision=8,
... suppress=False, threshold=1000, formatter=None)

자세한 도움말 은 "또는 부분"에 대한 numpy 문서 numpy 문서를 참조하십시오 .


3
사용하지 마십시오 'nan', np.nan또는 위의. 그것은 지원되지 않으며,이 나쁜 조언은 사람들이 파이썬 3으로 전환하는 데 고통을줍니다.
Eric

ValueError: threshold must be numeric and non-NAN, try sys.maxsize for untruncated representation
Eric
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.