Python jest dynamicznie typowanym i interpretowanym (w szczególnych przypadkach kompilowanym) językiem. Dynamiczne typowanie oznacza, że jakakolwiek zmienna (globalna czy lokalna w funkcji) nie posiada przypisanego typu. Dzięki temu kod jest bardzo krótki, elastyczny oraz jest pozbawiony sprawdzania typów na poziomie kompilacji, co znacząco skraca czas potrzebny od wprowadzenia zmian do uruchomienia kodu. Typ zmiennej jest sprawdzany dopiero w momencie wykonywania instrukcji, czyli jej konkretnego użycia. Dowolna zmienna staje się, np. integerem, w momencie gdy do niej przypiszemy wartość:
W powyższym przykładzie nie został przypisany żaden typ do zmiennej “a”, tylko konkretna wartość 5 która automatycznie informuje, że “a” od tej pory będzie integerem. Dynamiczne typowanie pozwala także na przypisanie innego typu do tej samej zmiennej, tzn.:
a = 5 # zmienna jest typu integer
a = 5. # a teraz jest typu float
a = "jakis text" # i na koniec typu string
Podobnie ma się sytuacja z funkcjami - nie trzeba deklarować typu argumentu, wystarczy że przekazaną wartość będzie dało się zastosować do instrukcji znajdujących się wewnątrz funkcji. Na przykład do funkcji:
def funkcja(argument1):
a = argument1[3]
return a
print funkcja([1, 2, 3, 4]) # wyswietli sie liczba 4
print funkcja("to jest string") #wyswietli sie znak "j"
można bez problemu przekazać zarówno listę jak i string, ponieważ oba te typy obsługują operator “[ ]”. Ważne jest jedynie, aby dało się wykonać wszystkie instrukcje znajdujące się wewnątrz funkcji, a nie ma znaczenia to czy przekazana jest lista, string czy jakikolwiek inny typ.
Pythona na ogół należy postrzegać jako język interpretowany, ponieważ w taki sposób zazwyczaj będziemy uruchamiać kod. Język interpretowany to taki, w którym nie dokonuje się kompilacji całości kodu na raz(przetwarzania kodu z języka w miarę łatwo zrozumiałego dla człowiek do kodu w postaci instrukcji przesyłanych do procesora). Kod w tym przypadku jest “kompilowany” w czasie jego wykonywania. Oznacza to, że w następna linijka naszego kodu zostanie “skompilowana” dopiero w momencie gdy skończy się wywoływać poprzednia instrukcja. Z językiem interpretowanym spotykamy się bardzo często, ponieważ jest nim “bash” - język obsługujący powłokę systemową Linuxa. Dlatego też wiele podobnych cech będzie widocznych w języku Python, jednak jest on dużo bardziej wygodny i naturalny w użytkowaniu. Oprócz swobody pisania kodu chyba najważniejszą zaletą Pythona jest właśnie czas od zapisania kodu do jego uruchomienia. Z racji tego że kod jest “kompilowany w locie” program uruchamia się błyskawicznie, co w przypadku dużych kodów w języku C/C++ bywa bardzo uciążliwe.
Kod Pythona może być pisany i uruchamiany w dwóch trybach:
Praca interaktywna z kodem sprowadza się do uruchomienia konsoli języka Python w której kod jest wykonywany po jego zatwierdzeniu klawiszem Enter. Aby uruchomić konsolę Pythona wystarczy z poziomu konsoli systemowej uruchomić aplikację “python”:
Po tej operacji środowisko konsoli systemowej zamieni się w środowisko konsoli Pythona i każda linijka będzie zaczynała się od znaku >>>:
Python 2.7.6 (default, Jun 22 2015, 17:58:13)
[GCC 4.8.2] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>>
Od tego momentu możemy pisać i od razu uruchamiać kolejne instrukcje, np.:
W trybie konsolowym można także definiować wieloliniowe instrukcje takie jak funkcje lub pętle. Dzięki temu, że każde takie wyrażenie kończy się znakiem “:”, to po naciśnięciu klawisza Enter środowisko automatycznie przechodzi w tryb wieloliniowy:
W powyższym przykładzie znak >>> został zamieniony na … który oznacza kolejne linie. Należy tutaj pamiętać, że ciała funkcji są zawsze przesunięte o jedną tabulację, w związku z czym w konsoli po znaku … także należy dodać jedną tabulację. W momencie gdy uznamy, że ciało funkcji należy zakończyć, to wystarczy wcisnąć Enter w linijce niezawierającej tabulacji, co zakończy definicję funkcji i konsola powróci do znaku >>>.
Na koniec, aby opuścić tryb konsolowy wystarczy wywołać funkcję exit lub w przypadku systemów Linux można także użyć skrótu CTRL+d:
Interaktywna konsola Pythona jest bardzo użyteczna w przypadku gdy chcemy zrobić jakąś prostą operację, np. obliczyć proste wyrażenie matematyczne bądź chcemy wykonać prostą operację na zbiorze plików.
Przejdźmy teraz do drugiego trybu - wsadowego. Ten tryb pozwala na uruchamianie kodu znajdującego się w pliku. Kod napisany w języku Python powinien zostać umieszczony w pliku o rozszerzeniu .py i każdy taki plik nazywany jest modułem (więcej o modułach się dalej). Aby uruchomić wybrany plik wystarczy przekazać ścieżkę do pliku do interpretera Pythona:
Można także pominąć interpreter przy wywołaniu i uruchamiać skrypt ta jak zwykłą aplikację. W takiej sytuacji trzeba dodać do pliku komentarz który poinformuje system który interpreter powinien być użyty do uruchomienia pliku
Oprócz linijki #!/bin/usr/python należy także zezwolić na uruchamianie pliku na poziomie systemu:
Powyższa metoda działa dokładnie tak samo jak w przypadku skryptów bash, gdzie w miejscu ścieżki korzystamy zazwyczaj z /bin/bash.
Każdy pojedynczy plik napisany w języku Python nazywany jest modułem. Każdy z modułów może być uruchamiany wprost (tak jak to zostało wcześniej opisane) lub zostać użyty w innym module. W tej sytuacji można w drugim module korzystać z funkcji, klas i zmiennych zawartych w pierwszym. Jednak aby skorzystać z funkcji należy odwołać się nie do samej nazwy np. funkcji, ale należy poprzedzić ją nazwą modułu (pliku):
Dzięki temu nazwy funkcji mogą być takie same w różnych plikach i nie powstanie konflikt. Każdy moduł stanowi swego rodzaju przestrzeń nazw wewnątrz której nazwy elementów języka nie mogą się powtarzać. Moduły rozpinają się nie tylko na pliki, ale także na struktury folderów. Jeśli plik znajduje się wewnątrz folderu o nazwie folder2, który z kolei znajduje w folderze folder1, to odwołanie do funkcji będzie miało następującą postać:
Jednym z najczęściej używanych elementów każdego języka są komentarze, które pozwalają na chwilowe wyłączenie kodu bądź dodanie notatki na temat danej instrukcji. W języku python w odróżnieniu od C/C++ komentować można tylko linię za pomocą znaku #
Jeśli chcemy dodać komentarz do kilku linii tekstu to niestety należy znak # umieścić na początku każdej z linii:
Może być to mało wygodne, jednak w praktyce, gdy korzystamy ze środowiska graficznego PyCharm wystarczy posłużyć się odpowiednim skrótem klawiszowym. Na przykład, gdy chcemy zamienić linijkę w której znajduje się nasz kursor to wystarczy wcisnąć na klawiaturze kombinację CTRL + /
Z kolei jeśli chcemy zamienić blok kodu na komentarz to należy go zaznaczyć a następnie ponownie skorzystać z kombinacji CTRL + /
Aby odkomentować ten sam blok tekstu wystarczy znów go zaznaczyć i użyć kombinacji CTRL + /.
Oprócz zwykłych komentarzy specyfikacja języka python przewiduje dodatkowy rodzaj komentarza, który jest automatycznie uznawany za dokumentację. Tekst dokumentacji powinien znaleźć się w pomiędzy znacznikami początku i końca. Jako znaczniki stosuje się trzykrotny znak cudzysłowu. Dokumentacja powinna znaleźć się tuż pod deklaracją dokumentowanego narzędzia, np. funkcji:
def funkcja(arg1, arg2):
"""
To jest funkcja, sluzy ona do robienia czegos
dziwnego z przekazanymi argumentami
"""
# kod zawierajacy cialo funkcji
pass
Środowisko PyCharm w przypadku dokumentacji jest także bardzo pomocne. Jeśli chcemy dodać taki rodzaj dokumentacji funkcji, wystarczy tuż pod jej nazwą dodać trzy znaki cudzysłowu i nacisnąć klawisz Enter a program automatycznie wygeneruje ciało dokumentacji w następującej postaci
Jak widać na powyższym rysunku PyCharm wygenerował dodatkowe elementy które wypada umieścić w dokumentacji. Tuż za znakami cudzysłowów została pozostawiona wolna linia w której należy umieścić opis funkcji, tzn. do czego służy i ewentualnie jaki algorytm implementuje. Oprócz tego PyCharm umieścił informację o argumentach funkcji:
Czasami programiści umieszczają pod argumentami dodatkowo przykład zastosowania funkcji.
Gdy już przygotujemy tak udokumentowaną funkcję, to możemy w środowisku PyCharm skorzystać z opcji “Quick Documentation” która wyświetla w dodatkowym oknie podpowiedzi to co zapisaliśmy lub ktoś inny udokumentował. Aby wyświetlić taką dokumentację należy postawić kursor na nazwie funkcji (w miejscu w którym chcemy z niej skorzystać) a następnie z górnego menu wybrać View/Quick Documentation
Dokumentacja kodu w języku python jest szczególnie ważna z uwagi na brak typów obiektów. Jeśli chcemy aby argument przekazany do funkcji był liczbą całkowitą, to nie możemy tego powiedzieć użytkownikowi za pomocą deklaracji funkcji (deklaracja zawiera tylko nazwy przekazanych zmiennych, nie ma typu) i musimy to zrobić za pośrednictwem dokumentacji.
W sytuacji gdy w komentarzach zostaną umieszczone polskie znaki diakrytyczne kod znajdujący się w danym pliku może nie uda się uruchomić. Wynika to z tego, że python używa domyślnego kodowania ASCII nieobsługującego tego typu znaków. Jeśli jednak chcemy używać polskich znaków, to na początku pliku należy wstawić następujący komentarz
Ta linijka wymusi na interpreterze skorzystanie z innego dekodera.
O zmiennych już wcześniej wspominaliśmy, teraz uzupełnimy te informacje. Najważniejsza cecha zmiennych to brak typu, z czym wiąże sie kilka cech. Po pierwsze typ zmiennej jest taki jak typ wprowadzonej wartości. Może być to jednak problematyczne, gdy chcemy wykonać operację (np. dzielenie) na konkretnie wybranym typie:
W wyniku działanie tej funkcji, zobaczymy 0, ponieważ funkcja została wywołana dla zmiennych integer. W tej sytuacji można problem rozwiązać przekazując poprawne wartości:
Można także rozwiązać ten problem w bardziej ogólny sposób, za pomocą funkcji konwertującej do odpowiedniego typu, np. float(…) :
Ponadto funkcje te potrafią konwertować string do wybranego typu, dlatego powyżej zdefiniowana funkcja zadziała i w takiej sytuacji:
Zmienne mogą być nazywane dowolnie, nawet tak samo jak funkcje wcześniej zaimportowane. W tej sytuacji obiekt “funkcja” zostanie zastąpiony inną wartością, przez co nie będziemy już mieli możliwości użyć funkcji. Sprawdź działanie następującego kodu:
Ta cecha języka może być jednak problematyczna, ponieważ wprowadza potencjalne błędy które trudno zlokalizować. O ile pisząc własne funkcje łatwo zauważyć taki problem, to w przypadku wbudowanych funkcji (zawsze dostępnych) takich jak list lub len jest to trudniejsze i trzeba na to uważać.
Już kilkukrotnie pokazywaliśmy jak wyglądają funkcje w języku Python. Teraz uzupełnimy tę wiedzę o 2 przydatne cechy. W Pythonie funkcjami można operować podobnie do zmiennych, ponieważ one są w rzeczywistości obiektami. Dzięki temu, można dowolnie zmieniać nazwę funkcji, bądź przypisywać im inne. Sprawdź poniższy kod:
Oraz działanie tego:
Druga bardzo ważna sprawa związana z funkcjami to przekazywanie jednej funkcji do drugiej. Z racji tego, że Python jest dynamicznie typowany to przekazanie funkcji do funkcji jest tak proste jak przekazanie argumentu. Czy wewnątrz funkcji zostanie ona użyta poprawnie dowiemy się dopiero w momencie uruchomienia kodu. Sprawdź poniższy przykład, który oblicza całkę metodą trapezów:
W języku C taki zakres określała się za pomocą klamer { }. W przypadku tego języka jeśli chcemy pozostawić “pustą” funkcję, to wystarczy zapisać jej ciało jako otwarcie i zamknięcie klamer:
A jak to jest w Pythonie? Przecież w Pythonie zakres ciała funkcji jest określony tylko przez indentację. Zatem czy nie ma takiej możliwości aby funkcja mogła być pozostawiona pusta? Jest, służy do tego słowo pass, które określa, że funkcja jest pusta i nie wykonuje żadnego kodu. Tak zdefiniowana funkcja wygląda następująco:
Do tej pory pokazaliśmy, jak wygląda definicja własnych funkcji. Python posiada jednak kilka podstawowych funkcji, które są zawsze dostępne i możemy z nich korzystać w dowolnym miejscu kodu. Należą do nich np.: print, float, int, str, len, range, dict, list, max, min. Niektóre funkcje zostaną wyjaśnione w dalszej części gdzie będziemy opisywali ich praktyczne zastosowanie. Zbiór i opis wbudowanych funkcji można znaleźć pod tym linkiem build-in functions
Jednym z najważniejszych elementów każdego języka jest kontener do przechowywania zbioru danych. W języku Python takim podstawowym typem jest lista, która może przechowywać elementy dowolnego typu, tzn. może przechowywać zarówno int jak i string w obrębie jednej listy. Ponadto listy są modyfikowalne, co oznacza, że do listy można dopisywać nowe elementy albo usuwać już znajdujące się w niej.
Pustą listę można utworzyć na 2 sposoby: - Za pomocą wbudowanej funkcji list:
Puste listy są mało przydatne, dlatego wykorzystując nawiasy [] można zadeklarować listę od razu wypełnioną:
Lista nie musi składać się z elementów tego samego typu:
Wiemy już jak umieszczać elementy, a jak je się pobiera? Tak samo jak w innych językach, używając nawiasów []. Należy jednak pamiętać, że listy są indeksowane o 0:
aList = [1, "dwa", 3. , 5]
print aList[0] # >> 1
print aList[1] # >> "dwa"
print aList[0] + aList[3] # >> 6
Aby sprawdzić rozmiar listy korzysta się z wbudowanej funkcji len:
Lista tak jak wszystkie zmienne jest obiektem, w związku z tym posiada przypisane do siebie funkcje, które operują na liście, na której zostały wywołane (funkcje takie nazywane są metodami i wywołuje się je podając jej nazwę tuż po nazwie listy, np. nazwaListy.nazwaFunkcji()) . Do tych funkcji należą: - nazwaListy.append(element) - metoda dodaje element na koniec listy, np.:
nazwaListy.remove(element) - metoda usuwa wskazany element z listy (podajemy wartość elementu, nie indeks),
nazwaListy.sort() - sortuje listę,
nazwaListy.reverse() - odwraca kolejność elementów w liście
Oprócz tych funkcji dla zmiennych typu list został dodatkowo przeciążony operator +. W kontekście użycia zmiennych typu list operator ten łączy 2 listy ze sobą:
Można także użyć operatora += zamiast metody append co spowoduje dodanie wszystkich elementów z jednej listy po prawej stronie do listy po lewej stronie operatora:
Język Python w specjalny sposób wspiera sprawdzanie czy element znajduje się w liście. Do tego służy słowo kluczowe in. Przeanalizujmy następujący kod:
aList = [1, 'cos', 2]
isInList = 'cos' in aList
print isInList # >> True
print 5 in aList # >> False
if 'cos' in aList:
print 'cos is in the aList'
Wyrażenie element in lista zwraca wartość logiczną True/False.
Jednym z najważniejszy elementów języków programowania są pętle. W przypadku Pythona pętla for różni się swojego odpowiednika w języku C/C++. W języku C aby pobrać z tablicy kolejne elementy piszemy:
Widać powyżej, że aby pobrać kolejne elementy z tablicy trzeba w pętli przesuwać indeks elementu i za każdym razem pobierać wartość z tablicy. Taka konstrukcja pętli jest bardzo często używana, dlatego w języku Python pętla for została sformułowana w następujący sposób:
Pętla for tutaj ma konstrukcję następującą:
Widzimy, że w Pythonie nie operujemy za pomocą indeksów, tylko od razu za pomocą kolejnych elementów z listy. Zmienna “elementListy” w każdym wywołaniu pętli przyjmuje kolejne wartości z listy.
Niestety, czasami przydaje się korzystanie z indeksów, np. gdy chcemy wykonać jakąś operację pewną ilość razy bez korzystania z listy. Niestety w takiej sytuacji Python wymaga czegoś, co będzie zawierało te indeksy:
W takiej sytuacji uciążliwe by było tworzenie takiej listy, dlatego można spodziewać się, że istnieje jakaś funkcje służąca do tego. I faktycznie, istniej i nazywa się range. Funkcja ta zwraca kolejne indeksy:
Musimy tutaj wyjaśnić pewną rzecz. Funkcja
range nie zwraca w rzeczywistości listy, tylko
tzw. generator. Generator różni się tym od
listy tym, że nie przechowuje elementów tylko generuje je na zapytanie o
kolejny element. Dlatego nawet w przypadku gdy użyjemy funkcji
range z bardzo dużą liczbą, to pamięć nie
zostanie zajęta. Funkcja range może przyjmować
kilka argumentów: 1. Koniec zakresu - range(10)
wygeneruje
liczby od 0 do 9. Koniec zakresu określa największą liczbę całkowitą
która już nie powinna być wygenerowana. Taka konstrukcja jest dopasowana
do indeksowania od 0. 2. Początek i koniec zakresu -
range(2,8)
wygeneruje liczby od 2 do 7. 3. Początek, koniec
i krok - range(2, 20, 3)
wygeneruje liczby [2, 5, 8, 11,
14, 12, 5, 8, 11, 14, 17] czyli od 2 do 20 co 3.
Często w trakcie pracy z listami okazuje się, że chcemy pracować nie na całej liście, lecz tylko na jej części. Do takich zadań bardzo przydatne są “wycinki” list, które pozwalają na pobranie np. 5 pierwszych elementów. Do tego służy znak “:”
aList = [1, 2, 5, 8, 4, 54, 12, 11]
print aList[:5] # >> wyswietli 5 pierwszych elementow [1,2,5,8,4]
print aList[5:] # >> wyswietli elementy od 5 do końca [54,12,11]
Można także łączyć oba zakresy
Ponadto można zdefiniować krok pomiędzy indeksami, np. co drugi element:
Ostatnia metoda dostępu do elementów to wykorzystanie ujemnego indeksu, który zwraca elementy licząc od końca, tj.:
Wycinki list działają praktycznie tak jak listy, tzn. można korzystać z nich w pętli for, np.:
lub przypisywać wartość do cześci elementów:
W dalszej części przedstawimy bibliotekę NumPy która obsługuje typ “array”, dla którego wycinki pozwalają na jeszcze większą swobodę.
Jak łatwo się domyślić listy wielowymiarowe to są po prostu listy przechowujące jako elementy kolejne listy. Aby stworzyć taką listę możemy po prostu skorzystać inicjalizacji […], gdzie elementami będą kolejne listy:
lista2D = [ [1,2], [2,3] ]
print "Element 0,0 =", lista2D[0][0] # >> wyswietli 1
print "Element 0,1 =", lista2D[0][1] # >> wyswietli 2
Listy wielowymiarowe zazwyczaj są potrzebne do przechowywania danych w postaci liczb (np. jako reprezentacja macierzy). W takiej sytuacji typ lista nie jest najlepszym kontenerem, ponieważ czas dostępu do zmiennych może się wydłużać. Do tego typu operacji najlepiej jest skorzystać z tablic pochodzących z biblioteki NumPy, która domyślnie obsługuje tablice wielowymiarowe i robi to bardzo efektywnie, ale o tym dalej.
Poprzednio pokazaliśmy, że listę można inicjalizować wartościami wpisanymi w prost pomiędzy nawiasami […]. Jednak ta metoda jest dość ograniczona, ponieważ explicite trudno wypełnić taką listę zbiorem np. 100 liczb. W takiej sytuacji lepiej już jest utworzyć pustą listę i skorzystać z metody append:
aList = list()
for i in range(100):
aList.append(i**2) # << wypelnienie listy kwadratem kolejnych liczb 0, 1, ..., 99
Powyższa struktura kodu jest poprawna, jednak tworzenie takiej pętli jest uciążliwe. Dlatego w Pythonie konstrukcja tego typu została uproszczona do:
Powyższy kod inicjalizuje listę kwadratem kolejnych liczb. Wyrażenie tuż przed for jest wartością która powinna uzupełniać kolejne elementy listy. Jest to kod który zazwyczaj znajduje się w ciele pętli for. Reszta składni tej konstrukcji typowa definicja pętli for. W miejscu wartości może także znajdować się wywołanie funkcji, a wynik jej działania będzie przypisany do kolejnych elementów, np.:
def inicjalizacja(index):
a = index / 2
b = index*a
return b
aList = [ inicjalizacja(i) for i in range(100)]
Ponieważ wewnątrz tej konstrukcji znajduje się zwykła pętla for, to po słowie “in” możemy wstawić dowolną inną listę:
Jak wiadomo w Pythonie nie korzystamy ze znaków “;” oznaczających koniec instrukcji. W tym języku z założenia koniec linii jest końcem pojedynczej instrukcji. Czy zatem istnieje możliwość inicjalizacji kilku zmiennych w jednej linii? Okazuje się, że tak. Służy do tego “rozwijanie list”, które pozwala przypisać kolejne wartości z listy (ogólniej z obiektu po którym można iterować) do zmiennych. Konstrukcja ta ma następującą postać:
Jeśli utworzymy listę w “locie” to okaże się, że możemy przypisać wartości do kilku zmiennych w jednej linii:
Podobnie można czynić z każdym obiektem który służy do przechowywania zbiorów (np. tuple i tablice numpy o których dalej).
Następnym typem który pozwala na przechowywanie danych jest tuple. Jego konstrukcja i użytkowanie jest podobne do list. Jednak w odróżnieniu od nich ten typ jest swego rodzaju listą niemodyfikowalną. Jeśli raz zostanie utworzony obiekt tego typu, to nie można zmieniać ani wartości znajdującuych się w nim ani liczby elementów. Obiekty typu tuple tworzy się podobnie do list z tą różnicą, że zamiast nawiasów [] korzystamy z ():
Poniważ jest on niemodyfikowalny, to nie posiada ani metody “append” ani nie jest możliwe przypisanie. Sprawdź poniższy kod:
Poza powyższymi uwagami tuple zachowuje się jak lista. To znaczy, że można go używać w pętlach:
oraz rozwijać tak jak listy:
Konstrukcja instrukcji if jest bardzo prosta, nawet przedstawialiśmy ją w niektórych przykładach. Przypomnijmy:
if wartosc_bool :
# instruckcje jesli wartosc jest prawda
else:
# instruckje jesli wartosc jest falszem
“wartosc_bool” powinna przyjmować wartość True lub
False, co może wynikać z warunku logicznego, np.:
a == b
lub a in aList
. Należy tutaj pamiętać,
że “:” musi znaleźć się także po słowie
else
Oprócz tej prostej konstrukcji często przydatne jest sprawdzanie drugiego warunku jeśli pierwszy nie jest spełniony. Do tego służy konstrukcja if- elif:
Poza danymi liczbowymi najczęściej będziemy musieli pracować z danymi w postaci ciągów znaków - typu string. W języku Python zmienną tego typu można tworzyć wykorzystując zarówno pojedynczy znak cudzysłowu ‘text’ lub podwójny “text”. Obie wersje są poprawne i mogą być używane zamiennie. Jednak zawsze lepiej jest przyjąć jedną konwencję i jej się trzymać.
Aby utworzyć zmienną pustą zmienną string można wykorzystać funkcję str:
lub nie podać żadnego znaku w cudzysłowie:
Aby złamać linię w tekście wystarczy użyć znaku “”, jednak w kodzie nadal będziemy pisali w tej samej linii, co jest bardzo nieczytelne. Python dodatkowo wspiera pisanie w postaci wieloliniowego tekstu. W tym celu korzysta się z potrójnego cudzysłowu:
Zmienne typu string są w rzeczywistości tablicami znaków, w związku z czym możemy nimi operować dokładnie tak jak tablicami:
aString = "Uwielbiam pisac w Pythonie"
print "Liczba znakow to w zdaniu", len(aString)
print "Trzeci znak to ", aString[2]
for znak in aString:
print znak
Z racji tego że w listach operator + służył do dodawania elementów do listy, to w przypadku stringów może posłużyć do łączenia tekstów:
Wycinki listy działają tak samo także na zmiennej string:
Z kolei jeśli chcemy połączyć string ze zmienną innego typu najlepiej jest skorzystać z funkcji konwertującej typy - str:
Oprócz konwersji zmiennych za pomocą funkcji str możemy jej dokonać przy pomocy formatowania tekstu, które jest podobne do tego znanego z języka C/C++ w funkcji “printf”. W przypadku C korzystaliśmy z funkcji, w Pythonie do tego celu używa się operatora %. Sprawdź działanie poniższego kodu
a = 5.234
formatedString = "Wartosc zmiennej a=%f" % a
print formatedString
formatedString = "Wartosc zmiennej a=%.2f" % a
print formatedString
b = 12
print "Wartosc zmiennej b = %03d" % b
W przypadku gdy chcemy sformatować więcej niż jedną zmienną, to należy przekazać argumenty do podmiany w postaci tuple:
Uwaga zmienne do sformatowania nie mogą być przekazane jako lista, ponieważ
Zmienne typu string podobnie jak list posiadają dodatkowe metody które pozwalają na wygodną pracę. Przydatne metody należące do klasy string to:
s.strip() - funkcja zwraca nowy string pozbawiony białych znaków na początku i końcu
s.isalpha() - sprawdza czy string zawiera tylko litery
Zanim zaczniesz rozwiązywać zadania przekopiuj poniższą funkcję na początek swojego pliku zawierającego:
def test(fun, *args):
print "".join(['-' for i in range(40)])
print fun.__name__[:-1].upper()+" "+fun.__name__[-1]
res = fun(*args[:-1])
if isinstance(args[0], str):
decoded = "".join([chr(i) for i in args[-1]])
if res == decoded:
print "Yes, "+decoded.replace("my","your")
else:
print "No, "+decoded.replace("my","your").replace("has","has not")+" yet"
else:
print "Is correct? "+ str(res == args[-1])
print "".join(['-' for i in range(40)])
Funkcja ta posłuży do testowania i wyświetlania informacji czy Twoja implementacja jest poprawna.
Przekopiuj poniższy kod do pliku, a następnie uzupełnij ciało funkcji. Zadaniem tej funkcji jest przetworzenie przekazanej listy (przekazana jako listObject) tak oby usunąć powtarzające się elementy ale tylko pomiędzy sąsiadami.
Przekopiuj poniższy kod do pliku, a następnie uzupełnij ciało funkcji. Funkcja ta powinna zwracać nową listę która jest sumą przekazanych list, tak aby kolejne elementy nowej listy składały się naprzemiennie, raz element z jednej listy a raz z drugiej. Uwaga, listy mogą nie być tej samej długości.
Przekopiuj poniższy kod do pliku, a następnie uzupełnij ciało funkcji. Funkcja powinna zwracać posortowaną listę elementów typu tuple. Sortowanie wykonaj biorąc pod uwagę ostatni element każdego tuple.
Przekopiuj poniższy kod do pliku, a następnie uzupełnij ciało funkcji.
def zadanie4(text):
# type your code
pass
test(zadanie4, "okmy$aiaetiaigaafbaf??a$okwatch$oafbusd$okhas$asbrsi31480$okended$aq340af", [109, 121, 32, 119, 97, 116, 99, 104, 32, 104, 97, 115, 32, 101, 110, 100, 101, 100])
Zadaniem tej funkcji “zadanie4” jest odczytanie ukrytego zdania w poniższym tekście:
“okmy\(aiaetiaigaafbaf??a\)okwatch\(oafbusd\)okhas\(asbrsi31480\)okended$aq340af”
Napis ten został zakodowany w następujący sposób: 1. do początku każdego wyrazu dodano “ok”, np: “To jest dom” -> “okTo okjest okdom” 2. za każdym oryginalnym wyrazem wstawiono dodatkowy losowy wyraz do zdania, np: “okTo okjest okdom” -> “okTo asifha okjest ??A?Sd okdom :asrof” 3. na koniec spacje zastąpione zostały znakiem “\(", np.: "okTo asifha okjest ??A?Sd okdom :asrof" -> "okTo\)asifha okjest\(??A?Sd\)okdom$:asrof”
To zadanie można rozwiązać za pomocą metod klasy string replace, join, startswith i split.
Jeśli ci się uda, to przerób program tak, aby rozkodowywanie było wykonane w jednej linii. Do tego celu może Ci się przydać poniższa konstrukcja inicjalizacji list:
Konstrukcja ta pozwala na umieszczenie elementu w liście jeśli jest spełniony jakiś warunek.
Napisz grę która będzie polegała na zgadywaniu liczby od 1-9 wylosowanej przez komputer. Wybrana przez użytkownika liczba powinna być wczytana z konsoli. Gra powinna się zakończyć gdy użytkownik trafi wylosowaną liczbę.
Zacznij swój kod od przekopiowania poniższej linii kodu
Linijka ta pozwoli na skorzystanie z funkcji “randint” która losuje liczby całkowite w wybranym zakresie.
Do wczytywanie danych z konsoli służy funkcje “input”, która jako argument przyjmuje tekst do wyświetlenia, np.: