Python2019/labs01/podstawy.py
2019-01-26 08:23:20 +01:00

387 lines
5.8 KiB
Python

#!/usr/bin/env python
# coding: utf-8
# # Podstawy Pythona: cz. 1
#
#  
#
# ## 26 stycznia 2019
# In[ ]:
contractions_expansions = {"don't": "do not"}
sentence = "I'd guess that it's Frank Sinatra."
sentence = sentence.replace(' \'', '\'')
sentence = sentence.replace(' n\'t', 'n\'t')
words = sentence.split()
for i in range(len(words)):
for contraction, expansion in contractions_expansions.items():
if contraction == words[i]:
words[i] = expansion
sentence = ' '.join(words)
# In[ ]:
print('Hello Python')
# In[4]:
print('Hello')
print('Python')
print('Hello', 'Python', '!')
# Typy proste:
# * liczby całkowite: `int`, np. `3`, `1000`, `-100`, `0`
# * liczby rzeczywiste: `float`: `3.14`, `5.0`, `-0.001`
# * napisy: `str`: `"Python"`, `"Rock'n'Roll"`, `'zalicznie z przedmiotu'`
# * logiczne `bool`, `True`, `False`
# * None: `None`
# In[6]:
print(10)
print(1000.0)
print (100, 100.0, "Sto")
print("Zaokrąglenie PI:", 3.141519)
# In[4]:
print(type(100))
print(type(20.5))
print(type("okno"))
print(type(None))
# Operacje arytmetyczne na liczbach:
# * dodawanie `+`, np. `2 + 3`
# * odejmowanie `-`, np. `10-9`
# * mnożenie `*`, np. `2.0 * 3.0`
# * dzielenie `/`, np. `3 / 4` ( == 0.75)
# * dzielenie całkowite `//`, `3 / 4` ( == 0)
# * potęgowanie `**`, np. `10 ** 3` ( == 1000)
# In[15]:
print(1 + 2 - 3)
print("2 ** 10", "=", 2 ** 10)
print(1 + 2 - 3 + (4 * 5) / 6 ** 2)
# Operacje na napisach:
# * konkatenacja `+`, np. `"Tarnowo " + "Podgórne"`
# * wielokrotność: `*`, np. `"O" * 6` ("OOOOOO")
# In[16]:
print("N" + "o" * 10 + '!')
# Konwersja typów:
# In[24]:
print(int("100") * 2)
print(str(100) * 2)
print(float(100) * 2)
print(bool("Fałsz"))
# ## Zmienne
# * case sensitive,
# * brak deklaracji typu,
# * do zmiennej można przypisać wszystko.
# In[2]:
user = "t.dwojak"
domain = "amu.edu.pl"
email = user + "@" + domain
print("email:", email)
# ## Komentarze
# * Komentarze nie są interpretowane.
# * Komentarze w Pythonie zaczynają się od znaku '#'
# * Istnieją komentarze wielolinijkowe tagowane potrójnym ", czyli """ """
#
# In[ ]:
print("Bardzo ważna wiadomość") # A to jest komentarz
"""
Komentarz
wielo-
linijkowy
"""
# print("Nie chcę być wydrukowanym")
print("A teraz chcę")
# # Podstawy cz. 2
# ## Listy
# * W Pythonie nie ma tablic, są listy;
# * Listy mogą przechowywać elementy różnych typów;
# * Indeksowanie zaczyna się od 0.
# * Funkcja `len` zwraca liczbę elementów listy
# In[32]:
x = [] # albo równoważnie pusta_lista = list()
oceny = [5, 4, 3, 5, 5]
roznosci = [3.14, "pi", ["pi"], 3]
list_0_9 = list(range(10))
print("Liczba elementów", len(oceny))
# In[33]:
print(oceny)
print(oceny[1])
# ## Dodawanie i usuwanie elementów z listy
#
# Istnieją dwie metody:
# * `append(x)`: dodaje x na koniec listy
# * `extend(x)`: rozszerza listę o każdy element z x
# In[13]:
engines = []
engines.append('duck-duck-go')
engines.append("yahoo")
print(engines)
# In[9]:
m = ["google", 'bing']
m.extend(l)
print(m)
# In[15]:
liczby = [1,2,3,2,3,1,2,4]
liczby.pop() # Domyślnie usuwa ostatni element z listy
liczby.remove(2)
print(liczby)
# Inne przydatne metody:
# * `sort()`: sortuje listę rosnąco
# * `count(x)`: zlicza wystąpienia x w liście
# * `index(x)`: zwraca indeks pierwszego wystąpienia x
# In[20]:
liczby = [1,2,3,2,3,1,2,4]
print(liczby.count(1))
print(liczby.index(4))
liczby.sort()
print(liczby)
# ## Indeksowanie
# In[21]:
oceny = [1, 3, 2, 3, 1, 2, 4]
print('pierwszy element:', oceny[0])
print('ostatni element:', oceny[-1])
print('5 pierwszych:', oceny[:5])
print('5 ostatnich', oceny[-5:])
print('od drugiego, do piątego', oceny[1:5])
print('parzyste:', oceny[1:6:2])
print('od tyłu', oceny[::-1])
# ## Pętla typu ```for```
# * W Pythonie pętla *for* działa jak pętla *for each* w innych językach;
# * W Pythonie nie ma klamr, ani *begin* i *end*; jako ciało pętli musi być wcięte (najcześciej 4 spacje).
# In[22]:
n = 3
for i in range(n):
print('element', i)
# In[23]:
l = ["jeden", "dwa", "trzy"]
for item in l:
print(item)
# In[24]:
kwadraty = []
for i in range(10):
kwadraty.append(i ** 2)
print(kwadraty)
# ## Słowniki: `dict`
# In[25]:
slownik = {}
s_oceny = {"Justyna" : [5,5,5], "Bartek" : [3,4,5], "Ola": [3,3,3]}
print(s_oceny)
# In[26]:
s_oceny["Jan"] = [3,4,5]
print(s_oceny)
# ## Iterowanie po słowniku
# In[27]:
for osoba in s_oceny:
print(osoba,':', s_oceny[osoba])
# In[ ]:
for osoba, oceny in s_oceny.items():
print(osoba,':', oceny)
# ## Instrukcja sterująca ```if ... else```
# * działa tak samo, jak w innych języka;
# * jest dodatkowa instrukcja następnego warunku *elif...*;
# In[30]:
zmienna = int(input("Podaj liczbe:\n"))
if zmienna < 0:
print("Ujemna!")
elif zmienna > 0:
print("Dodatnia")
else:
print("Zero!")
# ## Przydatne warunki
#
# * Porównanie za pomocą `==`
# * znak różności: `!=`
# * Sprawdzenie, czy coś jest w liście: `item in l`
# * Do łączenia warunków służą słowa klucznowe `and` i `or`
# In[ ]:
if "Ala" in s_oceny:
print("Ala jest w grupie!")
else:
print("Niestety Ali nie ma grupie!")
# # Łańcuchy znakowe
# In[ ]:
napis = "Wiadomość"
print(napis)
# In[ ]:
for znak in napis:
print(znak, ord(znak))
# In[ ]:
slowa = ['Bardzo' , 'ważna', 'wiadomość']
print(' '.join(slowa))
# In[ ]:
if 'dom' in napis:
print(True)
else:
print(False)
# In[ ]:
text = "Bardzo ważna wiadomość"
print(text.split(' '))
# In[ ]:
text = "Nie wszyscy lubią spacje na końcu linii. "
print(text)
print(text.strip(' '))
# # Pytania?
# ## Funkcje
# In[ ]:
def is_greater_than_5(x):
if x > 5:
return True
else:
return False
# In[ ]:
print(is_greater_than_5(5))
print(is_greater_than_5(-100))
print(is_greater_than_5(500))