처음 두 기사에서는 NumPy 배열에 대한 기본 소개를 제공했습니다. 이 기사에서는 NumPy 배열에 대해 더 심층적으로 설명합니다. 먼저 사용자 정의 유형의 배열을 소개한 다음 배열의 조합을 소개하고 마지막으로 배열 복사 문제를 소개합니다.
사용자 정의 구조 배열
C 언어와 같은 구조 유형도 NumPy를 통해 정의할 수 있습니다. NumPy에서 구조체를 정의하는 방법은 다음과 같습니다.
구조 유형 이름을 정의하고 필드 이름을 정의하고 필드 데이터 유형을 나타냅니다.
student= dtype({'names':['name', 'age', 'weight'], 'formats':['S32', 'i','f']}, align = True)
여기에서 Student는 첫 번째 매개변수인 'names' 및 'formats에서 dtype 함수를 사용하여 생성된 사용자 정의 구조 유형의 이름입니다. '변경할 수 없습니다. 이름에 나열된 이름은 구조의 필드 이름이고 나열된 형식은 해당 필드의 데이터 유형입니다. S32는 32바이트 길이의 문자열을 나타내고, i는 32비트 정수, f는 32비트 부동 소수점 숫자를 나타냅니다. 마지막 매개변수가 True이면 메모리 정렬이 필요함을 나타냅니다.
필드에서 데이터 유형을 나타내기 위해 NumPy 문자 인코딩이 사용됩니다. 자세한 데이터 유형은 아래 표를 참조하세요.
数据类型 | 字符编码 |
整数 | i |
无符号整数 | u |
单精度浮点数 | f |
双精度浮点数 | d |
布尔值 | b |
复数 | D |
字符串 | S |
Unicode | U |
Void | V |
구조 유형을 정의한 후 해당 유형을 요소로 사용하여 배열을 정의할 수 있습니다.
a= array([(“Zhang”, 32, 65.5), (“Wang”, 24, 55.2)], dtype =student)
각 요소의 해당 필드의 데이터를 나열하는 것 외에도 배열 함수의 마지막 매개변수에 해당 데이터 유형을 지정해야 합니다.
기능 결합
다음은 기능을 결합하는 다양한 방법입니다. 먼저 두 개의 배열을 만듭니다.
>>> a = arange(9).reshape(3,3) >>> a array([[0, 1, 2], [3, 4, 5], [6, 7, 8]]) >>> b = 2 * a >>> b array([[ 0, 2, 4], [ 6, 8, 10], [12, 14, 16]])
수평 조합
>>> hstack((a, b)) array([[ 0, 1, 2, 0, 2, 4], [ 3, 4, 5, 6, 8, 10], [ 6, 7, 8, 12, 14, 16]])
이 효과는 연결 기능을 통해서도 얻을 수 있으며 해당 축을 지정합니다:
>>> concatenate((a, b), axis=1) array([[ 0, 1, 2, 0, 2, 4], [ 3, 4, 5, 6, 8, 10], [ 6, 7, 8, 12, 14, 16]])
수직 조합
>>> vstack((a, b)) array([[ 0, 1, 2], [ 3, 4, 5], [ 6, 7, 8], [ 0, 2, 4], [ 6, 8, 10], [12, 14, 16]])
이 효과는 마찬가지로 연결 기능과 해당 축 지정을 통해 얻을 수 있습니다.
>>> concatenate((a, b), axis=0) array([[ 0, 1, 2], [ 3, 4, 5], [ 6, 7, 8], [ 0, 2, 4], [ 6, 8, 10], [12, 14, 16]])
깊이 조합
추가로 깊이 조합 기능인 dstack이 있습니다. 이름에서 알 수 있듯이 배열의 세 번째 축(즉, 깊이)에서 결합됩니다. 다음과 같습니다:
>>> dstack((a, b)) array([[[ 0, 0], [ 1, 2], [ 2, 4]], [[ 3, 6], [ 4, 8], [ 5, 10]], [[ 6, 12], [ 7, 14], [ 8, 16]]])
자세히 살펴보고 해당 요소가 새 목록으로 결합되어 새 배열의 요소로 사용되는지 확인하세요. .
행 조합
행 조합은 여러 개의 1차원 배열을 새 배열의 각 행으로 결합합니다.
>>> one = arange(2) >>> one array([0, 1]) >>> two = one + 2 >>> two array([2, 3]) >>> row_stack((one, two)) array([[0, 1], [2, 3]])
2D 배열의 경우 수직 조합처럼 작동합니다.
컬럼 조합
컬럼 조합의 효과가 명확해야 합니다.
>>> column_stack((oned, twiceoned)) array([[0, 2], [1, 3]])
2D 배열의 경우 수평 조합처럼 작동합니다.
배열 분할
NumPy에서 배열 분할 기능에는 hsplit, vsplit, dsplit 및 분할이 포함됩니다. 배열을 동일한 크기의 하위 배열로 분할하거나 원본 배열이 분할되는 위치를 지정할 수 있습니다.
수평 분할
>>> a = arange(9).reshape(3,3) >>> a array([[0, 1, 2], [3, 4, 5], [6, 7, 8]]) >>> hsplit(a, 3) [array([[0], [3], [6]]), array([[1], [4], [7]]), array([[2], [5], [8]])]
또한 분할 함수를 호출하고 축을 1로 지정하여 이를 얻습니다. 효과 :
split(a, 3, axis=1)
수직 분할
수직 분할은 수직 축을 따라 분할됩니다. 배열 :
>>> vsplit(a, 3) >>> [array([[0, 1, 2]]), array([[3, 4, 5]]), array([[6, 7, 8]])]
마찬가지로 solit 함수를 사용하고 축을 1로 지정하여 이 효과를 얻을 수도 있습니다.
>>> split(a, 3, axis=0)
깊이 중심 분할
dsplit 함수는 깊이 중심 분할 방법을 사용합니다.
>>> c = arange(27).reshape(3, 3, 3) >>> c array([[[ 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]]]) >>> dsplit(c, 3) [array([[[ 0], [ 3], [ 6]], [[ 9], [12], [15]], [[18], [21], [24]]]), array([[[ 1], [ 4], [ 7]], [[10], [13], [16]], [[19], [22], [25]]]), array([[[ 2], [ 5], [ 8]], [[11], [14], [17]], [[20], [23], [26]]])]
복사 및 미러링(보기)
어레이를 작동하고 처리할 때 해당 데이터가 때때로 새 어레이에 복사되지 않는 경우도 있습니다. 이것은 종종 초보자에게 혼란의 원인이 됩니다. 이에 대한 세 가지 경우가 있습니다:
전혀 복사하지 않음
배열 객체나 해당 데이터를 복사하지 않고 간단한 할당.
>>> a = arange(12) >>> b = a #不创建新对象 >>> b is a # a和b是同一个数组对象的两个名字 True >>> b.shape = 3,4 #也改变了a的形状 >>> a.shape (3, 4) Python 传递不定对象作为参考4,所以函数调用不拷贝数组。 >>> def f(x): ... print id(x) ... >>> id(a) #id是一个对象的唯一标识 148293216 >>> f(a) 148293216
보기 및 얕은 복사
다른 배열 객체는 동일한 데이터를 공유합니다. view 메소드는 동일한 데이터를 가리키는 새로운 배열 객체를 생성합니다.
>>> c = a.view() >>> c is a False >>> c.base is a #c是a持有数据的镜像 True >>> c.flags.owndata False >>> >>> c.shape = 2,6 # a的形状没变 >>> a.shape (3, 4) >>> c[0,4] = 1234 #a的数据改变了 >>> a array([[ 0, 1, 2, 3], [1234, 5, 6, 7], [ 8, 9, 10, 11]])
슬라이스된 배열은 해당 배열의 뷰를 반환합니다.
>>> s = a[ : , 1:3] # 获得每一行1,2处的元素 >>> s[:] = 10 # s[:] 是s的镜像。注意区别s=10 and s[:]=10 >>> a array([[ 0, 10, 10, 3], [1234, 10, 10, 7], [ 8, 10, 10, 11]])
전체 복사
이 복사 방법은 배열과 해당 데이터를 완전히 복사합니다.
>>> d = a.copy() #创建了一个含有新数据的新数组对象 >>> d is a False >>> d.base is a #d和a现在没有任何关系 False >>> d[0,0] = 9999 >>> a array([[ 0, 10, 10, 3], [1234, 10, 10, 7], [ 8, 10, 10, 11]])
위 글의 내용은 모두의 학습에 도움이 되었으면 좋겠습니다. PHP 중국어 웹사이트.
NumPy의 간결한 튜토리얼을 더 깊이 이해하려면---Array 3(조합) 관련 기사를 PHP 중국어 웹사이트에 주목하세요!

Python의 유연성은 다중 파리가 지원 및 동적 유형 시스템에 반영되며, 사용 편의성은 간단한 구문 및 풍부한 표준 라이브러리에서 나옵니다. 유연성 : 객체 지향, 기능 및 절차 프로그래밍을 지원하며 동적 유형 시스템은 개발 효율성을 향상시킵니다. 2. 사용 편의성 : 문법은 자연 언어에 가깝고 표준 라이브러리는 광범위한 기능을 다루며 개발 프로세스를 단순화합니다.

Python은 초보자부터 고급 개발자에 이르기까지 모든 요구에 적합한 단순성과 힘에 호의적입니다. 다목적 성은 다음과 같이 반영됩니다. 1) 배우고 사용하기 쉽고 간단한 구문; 2) Numpy, Pandas 등과 같은 풍부한 라이브러리 및 프레임 워크; 3) 다양한 운영 체제에서 실행할 수있는 크로스 플랫폼 지원; 4) 작업 효율성을 향상시키기위한 스크립팅 및 자동화 작업에 적합합니다.

예, 하루에 2 시간 후에 파이썬을 배우십시오. 1. 합리적인 학습 계획 개발, 2. 올바른 학습 자원을 선택하십시오. 3. 실습을 통해 학습 된 지식을 통합하십시오. 이 단계는 짧은 시간 안에 Python을 마스터하는 데 도움이 될 수 있습니다.

Python은 빠른 개발 및 데이터 처리에 적합한 반면 C는 고성능 및 기본 제어에 적합합니다. 1) Python은 간결한 구문과 함께 사용하기 쉽고 데이터 과학 및 웹 개발에 적합합니다. 2) C는 고성능과 정확한 제어를 가지고 있으며 게임 및 시스템 프로그래밍에 종종 사용됩니다.

Python을 배우는 데 필요한 시간은 개인마다 다릅니다. 주로 이전 프로그래밍 경험, 학습 동기 부여, 학습 리소스 및 방법 및 학습 리듬의 영향을받습니다. 실질적인 학습 목표를 설정하고 실용적인 프로젝트를 통해 최선을 다하십시오.

파이썬은 자동화, 스크립팅 및 작업 관리가 탁월합니다. 1) 자동화 : 파일 백업은 OS 및 Shutil과 같은 표준 라이브러리를 통해 실현됩니다. 2) 스크립트 쓰기 : PSUTIL 라이브러리를 사용하여 시스템 리소스를 모니터링합니다. 3) 작업 관리 : 일정 라이브러리를 사용하여 작업을 예약하십시오. Python의 사용 편의성과 풍부한 라이브러리 지원으로 인해 이러한 영역에서 선호하는 도구가됩니다.

제한된 시간에 Python 학습 효율을 극대화하려면 Python의 DateTime, Time 및 Schedule 모듈을 사용할 수 있습니다. 1. DateTime 모듈은 학습 시간을 기록하고 계획하는 데 사용됩니다. 2. 시간 모듈은 학습과 휴식 시간을 설정하는 데 도움이됩니다. 3. 일정 모듈은 주간 학습 작업을 자동으로 배열합니다.

Python은 게임 및 GUI 개발에서 탁월합니다. 1) 게임 개발은 Pygame을 사용하여 드로잉, 오디오 및 기타 기능을 제공하며 2D 게임을 만드는 데 적합합니다. 2) GUI 개발은 Tkinter 또는 PYQT를 선택할 수 있습니다. Tkinter는 간단하고 사용하기 쉽고 PYQT는 풍부한 기능을 가지고 있으며 전문 개발에 적합합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

드림위버 CS6
시각적 웹 개발 도구

Dreamweaver Mac版
시각적 웹 개발 도구
