요약
np.array()와 np.asarray()는 NumPy에서 배열을 생성하는 함수입니다.
그러나 두 함수 사이에는 몇 가지 차이점이 있습니다. 데이터가 복사가 되는지 여부와, 데이터 유형이 변화되는지 여부의 차이가 있습니다.
차이점 비교
- 복사 여부
- np.array(): 기본적으로 배열의 복사본을 생성합니다.
- np.asarray(): 배열의 복사본을 생성하지 않고, 가능한 경우에는 입력 배열의 뷰(view)를 반환합니다. 즉, 입력 배열과 반환된 배열이 메모리를 공유할 수 있습니다.
- 데이터 유형 변환:
- np.array(): 입력된 데이터의 유형에 따라 새로운 배열의 데이터 유형이 결정됩니다. 필요에 따라 데이터 유형을 명시적으로 지정할 수도 있습니다.
- np.asarray(): 입력된 배열과 동일한 데이터 유형을 갖는 배열을 생성합니다. 따라서 입력 배열의 데이터 유형을 유지합니다.
코드 비교
간단한 예제로 두 함수의 동작을 살펴보겠습니다. 아래의 예제에서 np.array()를 사용하여 배열 arr1을 생성하고, 이를 np.asarray()로 배열 arr2를 생성합니다. 그런 다음 arr1의 첫 번째 요소를 변경하면 arr2도 동일하게 변경됩니다. 즉, np.asarray()는 입력 배열과 같은 데이터를 참조하므로 변경 사항이 반영됩니다. 즉, arr1의 0번 인덱스만 변경했음에도, np.asarray은 array을 데이터를 그대로 참조하며, 뷰를 생성하므로 arr1을 변경함에따라 arr2도 변경됩니다.
요약하자면, np.array()는 항상 복사본을 생성하며, 데이터 유형 변환을 수행할 수 있습니다. np.asarray()는 가능한 경우에는 복사본 대신 입력 배열의 뷰를 반환하며, 데이터 유형 변환은 수행하지 않고 입력 배열의 데이터 유형을 유지합니다.
import numpy as np
arr1 = np.array([1, 2, 3])
arr2 = np.asarray(arr1)
arr1[0] = 99
print(arr1) # 출력: [99 2 3]
print(arr2) # 출력: [99 2 3]
반응형
'Data science > Python' 카테고리의 다른 글
[에러처리] conda: error: argument COMMAND: invalid choice: 'activate' (0) | 2023.10.10 |
---|---|
jupyter-notebook 라이브러리 자동 갱신 (0) | 2023.08.26 |
문자열 조작: 애너그램 / 필린드롬 부문 문자 (0) | 2021.11.21 |
Set, Dict의 자료구조가 검색이 빠른 이유? hash 함수 (0) | 2021.10.02 |
Python stuck사용법 (16진법) (0) | 2021.08.01 |