Python 3 - typy zmiennych
Zmienne to nic innego jak zarezerwowane miejsca w pamięci do przechowywania wartości. Oznacza to, że kiedy tworzysz zmienną, rezerwujesz trochę miejsca w pamięci.
Na podstawie typu danych zmiennej interpreter przydziela pamięć i decyduje, co może być przechowywane w zarezerwowanej pamięci. Dlatego przypisując różne typy danych do zmiennych, można przechowywać w tych zmiennych liczby całkowite, dziesiętne lub znaki.
Przypisywanie wartości do zmiennych
Zmienne Pythona nie wymagają jawnej deklaracji, aby zarezerwować miejsce w pamięci. Deklaracja jest wykonywana automatycznie po przypisaniu wartości do zmiennej. Znak równości (=) służy do przypisywania wartości zmiennym.
Operand po lewej stronie operatora = to nazwa zmiennej, a operand po prawej stronie operatora = to wartość przechowywana w zmiennej. Na przykład -
#!/usr/bin/python3
counter = 100 # An integer assignment
miles = 1000.0 # A floating point
name = "John" # A string
print (counter)
print (miles)
print (name)
W tym przypadku 100, 1000,0 i „John” to wartości przypisane odpowiednio do zmiennych licznika, mil i nazw. Daje to następujący wynik -
100
1000.0
John
Przydział wielokrotny
Python umożliwia jednoczesne przypisanie jednej wartości do kilku zmiennych.
Na przykład -
a = b = c = 1
Tutaj tworzony jest obiekt typu integer o wartości 1, a wszystkie trzy zmienne są przypisywane do tego samego miejsca w pamięci. Możesz także przypisać wiele obiektów do wielu zmiennych. Na przykład -
a, b, c = 1, 2, "john"
Tutaj dwa obiekty typu integer o wartościach 1 i 2 są przypisane odpowiednio do zmiennych a i b, a jeden obiekt typu string o wartości „john” jest przypisany do zmiennej c.
Standardowe typy danych
Dane przechowywane w pamięci mogą być różnego rodzaju. Na przykład wiek osoby jest przechowywany jako wartość numeryczna, a jej adres jako znaki alfanumeryczne. Python ma różne standardowe typy danych, które są używane do definiowania możliwych na nich operacji i metod przechowywania dla każdego z nich.
Python ma pięć standardowych typów danych -
- Numbers
- String
- List
- Tuple
- Dictionary
Liczby w Pythonie
Typy danych liczbowych przechowują wartości liczbowe. Obiekty liczbowe są tworzone po przypisaniu im wartości. Na przykład -
var1 = 1
var2 = 10
Możesz również usunąć odwołanie do obiektu liczbowego przy użyciu rozszerzenia delkomunikat. Składniadel oświadczenie to -
del var1[,var2[,var3[....,varN]]]]
Możesz usunąć pojedynczy obiekt lub wiele obiektów, używając rozszerzenia del komunikat.
Na przykład -
del var
del var_a, var_b
Python obsługuje trzy różne typy liczbowe -
- int (liczby całkowite ze znakiem)
- float (zmiennoprzecinkowe wartości rzeczywiste)
- zespolone (liczby zespolone)
Wszystkie liczby całkowite w Pythonie3 są reprezentowane jako długie liczby całkowite. Dlatego nie ma tak długiego oddzielnego typu liczb.
Przykłady
Oto kilka przykładów liczb -
int | pływak | złożony |
---|---|---|
10 | 0.0 | 3.14j |
100 | 15.20 | 45.j |
-786 | -21,9 | 9.322e-36j |
080 | 32,3 + e18 | .876j |
-0490 | -90. | -.6545 + 0J |
-0x260 | -32,54e100 | 3e + 26J |
0x69 | 70,2-E12 | 4.53e-7j |
Liczba zespolona składa się z uporządkowanej pary rzeczywistych liczb zmiennoprzecinkowych oznaczonych przez x + yj, gdzie x i y są liczbami rzeczywistymi, a j jest jednostką urojoną.
Ciągi Pythona
Ciągi znaków w Pythonie są identyfikowane jako ciągły zestaw znaków przedstawionych w cudzysłowie. Python pozwala na używanie pary pojedynczych lub podwójnych cudzysłowów. Podzbiory łańcuchów można pobrać za pomocą operatora wycinka ([] i [:]) z indeksami zaczynającymi się od 0 na początku łańcucha i przesuwającymi się od -1 do końca.
Znak plus (+) to operator konkatenacji ciągów, a gwiazdka (*) to operator powtarzania. Na przykład -
#!/usr/bin/python3
str = 'Hello World!'
print (str) # Prints complete string
print (str[0]) # Prints first character of the string
print (str[2:5]) # Prints characters starting from 3rd to 5th
print (str[2:]) # Prints string starting from 3rd character
print (str * 2) # Prints string two times
print (str + "TEST") # Prints concatenated string
To da następujący wynik -
Hello World!
H
llo
llo World!
Hello World!Hello World!
Hello World!TEST
Listy w Pythonie
Listy są najbardziej wszechstronnymi złożonymi typami danych Pythona. Lista zawiera elementy oddzielone przecinkami i zawarte w nawiasach kwadratowych ([]). Do pewnego stopnia listy są podobne do tablic w C. Jedną z różnic między nimi jest to, że wszystkie elementy należące do listy mogą mieć różne typy danych.
Dostęp do wartości przechowywanych na liście można uzyskać za pomocą operatora wycinka ([] i [:]) z indeksami zaczynającymi się od 0 na początku listy i prowadzącymi do końca -1. Znak plus (+) to operator konkatenacji listy, a gwiazdka (*) to operator powtórzenia. Na przykład -
#!/usr/bin/python3
list = [ 'abcd', 786 , 2.23, 'john', 70.2 ]
tinylist = [123, 'john']
print (list) # Prints complete list
print (list[0]) # Prints first element of the list
print (list[1:3]) # Prints elements starting from 2nd till 3rd
print (list[2:]) # Prints elements starting from 3rd element
print (tinylist * 2) # Prints list two times
print (list + tinylist) # Prints concatenated lists
Daje to następujący wynik -
['abcd', 786, 2.23, 'john', 70.200000000000003]
abcd
[786, 2.23]
[2.23, 'john', 70.200000000000003]
[123, 'john', 123, 'john']
['abcd', 786, 2.23, 'john', 70.200000000000003, 123, 'john']
Krotki Pythona
Krotka to inny typ danych sekwencji, który jest podobny do listy. Krotka składa się z szeregu wartości oddzielonych przecinkami. Jednak w przeciwieństwie do list krotki są ujęte w nawiasach.
Główną różnicą między listami a krotkami jest - Listy są ujęte w nawiasy kwadratowe ([]), a ich elementy i rozmiar można zmieniać, podczas gdy krotki są zawarte w nawiasach (()) i nie można ich aktualizować. Krotki można traktować jakoread-onlylisty. Na przykład -
#!/usr/bin/python3
tuple = ( 'abcd', 786 , 2.23, 'john', 70.2 )
tinytuple = (123, 'john')
print (tuple) # Prints complete tuple
print (tuple[0]) # Prints first element of the tuple
print (tuple[1:3]) # Prints elements starting from 2nd till 3rd
print (tuple[2:]) # Prints elements starting from 3rd element
print (tinytuple * 2) # Prints tuple two times
print (tuple + tinytuple) # Prints concatenated tuple
Daje to następujący wynik -
('abcd', 786, 2.23, 'john', 70.200000000000003)
abcd
(786, 2.23)
(2.23, 'john', 70.200000000000003)
(123, 'john', 123, 'john')
('abcd', 786, 2.23, 'john', 70.200000000000003, 123, 'john')
Poniższy kod jest nieprawidłowy z krotką, ponieważ próbowaliśmy zaktualizować krotkę, co jest niedozwolone. Podobny przypadek jest możliwy w przypadku list -
#!/usr/bin/python3
tuple = ( 'abcd', 786 , 2.23, 'john', 70.2 )
list = [ 'abcd', 786 , 2.23, 'john', 70.2 ]
tuple[2] = 1000 # Invalid syntax with tuple
list[2] = 1000 # Valid syntax with list
Słownik Pythona
Słowniki Pythona są rodzajem tablic mieszających. Działają jak tablice asocjacyjne lub skróty występujące w Perlu i składają się z par klucz-wartość. Klucz słownika może być prawie dowolnego typu w Pythonie, ale zwykle są to liczby lub łańcuchy. Z drugiej strony wartościami mogą być dowolne obiekty w Pythonie.
Słowniki są ujęte w nawiasy klamrowe ({}), a wartości można przypisywać i uzyskiwać do nich dostęp za pomocą nawiasów kwadratowych ([]). Na przykład -
#!/usr/bin/python3
dict = {}
dict['one'] = "This is one"
dict[2] = "This is two"
tinydict = {'name': 'john','code':6734, 'dept': 'sales'}
print (dict['one']) # Prints value for 'one' key
print (dict[2]) # Prints value for 2 key
print (tinydict) # Prints complete dictionary
print (tinydict.keys()) # Prints all the keys
print (tinydict.values()) # Prints all the values
Daje to następujący wynik -
This is one
This is two
{'name': 'john', 'dept': 'sales', 'code': 6734}
dict_keys(['name', 'dept', 'code'])
dict_values(['john', 'sales', 6734])
Słowniki nie mają koncepcji porządku między elementami. Nieprawidłowe jest stwierdzenie, że elementy są „niesprawne”; są po prostu nieuporządkowane.
Konwersja typu danych
Czasami może być konieczne wykonanie konwersji między typami wbudowanymi. Aby dokonać konwersji między typami, po prostu użyj nazw typów jako funkcji.
Istnieje kilka wbudowanych funkcji do przeprowadzania konwersji z jednego typu danych na inny. Te funkcje zwracają nowy obiekt reprezentujący przekonwertowaną wartość.
Sr.No. | Opis funkcji |
---|---|
1 | int(x [,base]) Konwertuje x na liczbę całkowitą. Baza określa podstawę, jeśli x jest łańcuchem. |
2 | float(x) Konwertuje x na liczbę zmiennoprzecinkową. |
3 | complex(real [,imag]) Tworzy liczbę zespoloną. |
4 | str(x) Konwertuje obiekt x na reprezentację w postaci ciągu. |
5 | repr(x) Konwertuje obiekt x na ciąg wyrażenia. |
6 | eval(str) Oblicza ciąg i zwraca obiekt. |
7 | tuple(s) Konwertuje s na krotkę. |
8 | list(s) Konwertuje s na listę. |
9 | set(s) Konwertuje s na zbiór. |
10 | dict(d) Tworzy słownik. d musi być sekwencją krotek (klucz, wartość). |
11 | frozenset(s) Konwertuje s na zestaw zamrożony. |
12 | chr(x) Konwertuje liczbę całkowitą na znak. |
13 | unichr(x) Konwertuje liczbę całkowitą na znak Unicode. |
14 | ord(x) Konwertuje pojedynczy znak na jego wartość całkowitą. |
15 | hex(x) Konwertuje liczbę całkowitą na ciąg szesnastkowy. |
16 | oct(x) Konwertuje liczbę całkowitą na ciąg ósemkowy. |