NumPy - typy danych

NumPy obsługuje znacznie większą różnorodność typów liczbowych niż Python. W poniższej tabeli przedstawiono różne skalarne typy danych zdefiniowane w NumPy.

Sr.No. Typy danych i opis
1

bool_

Wartość logiczna (prawda lub fałsz) przechowywana jako bajt

2

int_

Domyślny typ liczby całkowitej (taki sam jak C long; zwykle int64 lub int32)

3

intc

Identyczne z C int (zwykle int32 lub int64)

4

intp

Liczba całkowita używana do indeksowania (taka sama jak C ssize_t; zwykle int32 lub int64)

5

int8

Bajty (od -128 do 127)

6

int16

Liczba całkowita (od -32768 do 32767)

7

int32

Liczba całkowita (od -2147483648 do 2147483647)

8

int64

Liczba całkowita (od -9223372036854775808 do 9223372036854775807)

9

uint8

Liczba całkowita bez znaku (od 0 do 255)

10

uint16

Liczba całkowita bez znaku (od 0 do 65535)

11

uint32

Liczba całkowita bez znaku (od 0 do 4294967295)

12

uint64

Liczba całkowita bez znaku (od 0 do 18446744073709551615)

13

float_

Skrót do float64

14

float16

Półprecyzyjny float: bit znaku, wykładnik 5-bitowy, mantysa 10-bitowa

15

float32

Liczba zmiennoprzecinkowa pojedynczej precyzji: bit znaku, wykładnik 8-bitowy, mantysa 23-bitowa

16

float64

Pływak podwójnej precyzji: bit znaku, 11-bitowy wykładnik, 52-bitowa mantysa

17

complex_

Skrót dla kompleksu 128

18

complex64

Liczba zespolona reprezentowana przez dwa 32-bitowe liczby zmiennoprzecinkowe (składniki rzeczywiste i urojone)

19

complex128

Liczba zespolona reprezentowana przez dwa 64-bitowe liczby zmiennoprzecinkowe (składniki rzeczywiste i urojone)

Typy liczbowe NumPy to instancje obiektów dtype (typ danych), z których każdy ma unikalne cechy. Typy są dostępne jako np.bool_, np.float32 itd.

Obiekty typu danych (dtype)

Obiekt typu danych opisuje interpretację stałego bloku pamięci odpowiadającego tablicy, w zależności od następujących aspektów -

  • Typ danych (liczba całkowita, zmiennoprzecinkowa lub obiekt Pythona)

  • Rozmiar danych

  • Kolejność bajtów (little-endian lub big-endian)

  • W przypadku typu strukturalnego, nazwy pól, typ danych każdego pola i część bloku pamięci zajmowana przez każde pole.

  • Jeśli typ danych to podtablica, jej kształt i typ danych

O kolejności bajtów decyduje przedrostek „<” lub „>” do typu danych. „<” oznacza, że ​​kodowanie jest little-endian (najmniej znaczące jest przechowywane w najmniejszym adresie). „>” oznacza, że ​​kodowanie jest big-endian (najbardziej znaczący bajt jest przechowywany w najmniejszym adresie).

Obiekt dtype jest konstruowany przy użyciu następującej składni -

numpy.dtype(object, align, copy)

Parametry to -

  • Object - Do konwersji na obiekt typu danych

  • Align - Jeśli prawda, dodaje wypełnienie do pola, aby uczynić je podobnym do struktury C

  • Copy- Tworzy nową kopię obiektu dtype. Jeśli false, wynik jest odniesieniem do wbudowanego obiektu typu danych

Przykład 1

# using array-scalar type 
import numpy as np 
dt = np.dtype(np.int32) 
print dt

Dane wyjściowe są następujące -

int32

Przykład 2

#int8, int16, int32, int64 can be replaced by equivalent string 'i1', 'i2','i4', etc. 
import numpy as np 

dt = np.dtype('i4')
print dt

Dane wyjściowe są następujące -

int32

Przykład 3

# using endian notation 
import numpy as np 
dt = np.dtype('>i4') 
print dt

Dane wyjściowe są następujące -

>i4

Poniższe przykłady pokazują użycie typu danych strukturalnych. W tym miejscu należy zadeklarować nazwę pola i odpowiedni skalarny typ danych.

Przykład 4

# first create structured data type 
import numpy as np 
dt = np.dtype([('age',np.int8)]) 
print dt

Dane wyjściowe są następujące -

[('age', 'i1')]

Przykład 5

# now apply it to ndarray object 
import numpy as np 

dt = np.dtype([('age',np.int8)]) 
a = np.array([(10,),(20,),(30,)], dtype = dt) 
print a

Dane wyjściowe są następujące -

[(10,) (20,) (30,)]

Przykład 6

# file name can be used to access content of age column 
import numpy as np 

dt = np.dtype([('age',np.int8)]) 
a = np.array([(10,),(20,),(30,)], dtype = dt) 
print a['age']

Dane wyjściowe są następujące -

[10 20 30]

Przykład 7

W poniższych przykładach zdefiniowano uporządkowany typ danych o nazwie student z polem tekstowym „nazwa”, an integer field „wiek” i a float field'znaki'. Ten typ dtype jest stosowany do obiektu ndarray.

import numpy as np 
student = np.dtype([('name','S20'), ('age', 'i1'), ('marks', 'f4')]) 
print student

Dane wyjściowe są następujące -

[('name', 'S20'), ('age', 'i1'), ('marks', '<f4')])

Przykład 8

import numpy as np 

student = np.dtype([('name','S20'), ('age', 'i1'), ('marks', 'f4')]) 
a = np.array([('abc', 21, 50),('xyz', 18, 75)], dtype = student) 
print a

Dane wyjściowe są następujące -

[('abc', 21, 50.0), ('xyz', 18, 75.0)]

Każdy wbudowany typ danych ma kod znaku, który go jednoznacznie identyfikuje.

  • 'b' - boolean

  • 'i' - liczba całkowita (ze znakiem)

  • 'u' - liczba całkowita bez znaku

  • 'f' - zmiennoprzecinkowe

  • 'c' - zespolone zmiennoprzecinkowe

  • 'm' - timedelta

  • 'M' - data i godzina

  • 'O' - obiekty (Python)

  • 'S', 'a' - (bajt-) ciąg

  • 'U' - Unicode

  • 'V' - surowe dane (nieważne)