Regulární výrazy, práce s textem a daty. IB111 Úvod do programování skrze Python
|
|
- Monika Bílková
- před 6 lety
- Počet zobrazení:
Transkript
1 Regulární výrazy, práce s textem a daty IB111 Úvod do programování skrze Python / 57
2 Výhled dnes: práce s textem příště: práce s obrázky příkazy pro práci s textem/obrázky ukázky na konkrétních příkladech použití dříve probíraných konstrukcí uvažování o problémech, volba přístupu, kladení otázek 2 / 57
3 Práce s textem Příklady: statistiky o studentech frekvenční analýza textu zpracování dotazníku, ankety 3 / 57
4 Čeština v tomto kurzu pro zjednodušení pracujeme jen s anglickou abecedou resp. s texty bez hacku a carek pro zájemce viz např. základ: specifikovat kódování na začátku souboru # -*- coding: utf-8 -*- 4 / 57
5 Regulární výrazy: motivace vyhledání ových adres v textu vyhledání odkazů v HTML dokumentu náhrada jméno příjmení za příjmení jméno změna formátu datumů odstranění bílých znaků 5 / 57
6 Regulární výrazy: použití programování textové editory příkazová řádka: např. grep teorie: formální jazyky, konečné automaty 6 / 57
7 7 / 57
8 Regulární výrazy obecně používaný nástroj základní syntax stejná ve většině jazyků, prostředí následuje: základní syntax regulárních výrazů použití v Pythonu nerozebíráme všechny technické detaily (podrobněji viz dokumentace) 8 / 57
9 Ukázka import re f = open("testovaci-soubor.txt") for radek in f.readlines(): if re.search(r [a-z]+@[a-z]+\.cz, radek): print radek f.close() 9 / 57
10 Znaky a speciální znaky základní znak vyhoví právě sám sobě např. cz v předchozím příkladě speciální znaky:. ^ $ * +? { } [ ] \ ( ) umožňují konstrukci složitějších výrazů chceme, aby odpovídaly příslušnému symbolu prefix \ 10 / 57
11 Výběr ze skupiny znaků [] [abc] jeden ze znaků a, b, c [a-z] výběr z intervalu (malé písmeno anglické abecedy) ^ na začátku výběru = negace: [^abc] cokoliv jiného než a, b, c 11 / 57
12 Často používané skupiny znaků \d Čísla: [0-9] \D Cokoliv kromě čísel: [^0-9] \s Bílé znaky: [ \t\n\r\f\v] \S Cokoliv kromě bílých znaků: [^ \t\n\r\f\v] \w Alfanumerické znaky: [a-za-z0-9_] \W Nealfanumerické znaky: [^a-za-z0-9_] 12 / 57
13 Speciální symboly. libovolný znak ^ začátek řetězce $ konec řetězce alternativa výběr jedné ze dvou možností 13 / 57
14 Příklady Jaký je význam následujících výrazů? kocka pes ^[Pp]rase$ \d[a-z]\d \d\d\d\d 14 / 57
15 Opakování * nula a více opakování + jedno a více opakování? nula nebo jeden výskyt {m,n} m až n opakování Pozn. *, + jsou hladové, pro co nejmenší počet opakování *?, +? 15 / 57
16 Příklady Jaký je význam následujících výrazů? ^\s*nadpis ^a.+a$ \d{3}\s?\d{3}\s?\d{3} ^To:\s*(fi 16 / 57
17 Příklady Která z následujících slov vyhoví jednotlivým výrazům? ps pes pse poe prase poklice p[ars]e p[ars]*e p[^ars]e 17 / 57
18 Příklady Která z následujících slov vyhoví jednotlivým výrazům? p[ars]e p[ars]*e p[^ars]e ps pes pse poe prase poklice 18 / 57
19 Kontrola tabulky v Pythonu texty = ["ps","pes","pse","poe","prase","poklice"] vyrazy = [ r p[ars]e, r p[ars]*e, r p[^ars]e ] for text in texty: print text, for vyraz in vyrazy: if re.search(vyraz, text): print 1, else: print 0, print 19 / 57
20 Regulární výrazy: xkcd / 57
21 Regulární výrazy v Pythonu knihovna re (import re) re.match hledá shodu na začátku řetězce re.search hledá shodu kdekoliv v řetězci (re.compile pro větší efektivitu) raw string r vyraz nedochází k interpretaci speciálních znaků jako u běžných řetězců v Pythonu 21 / 57
22 Regulární výrazy v Pythonu: práce s výsledkem match/search vrací MatchObject pomocí kterého můžeme s výsledkem pracovat pomocí kulatých závorek () označíme, co nás zajímá Alice\s+(\w+) 22 / 57
23 Regulární výrazy v Pythonu: práce s výsledkem >>> m = re.match(r"(\w+) (\w+)", \ "Isaac Newton, fyzik") >>> m.group(0) Isaac Newton >>> m.group(1) Isaac >>> m.group(2) Newton 23 / 57
24 Substituce nahrazení řetězce jiným výrazem nejen statické řetězce, ale i regulární výrazy re.sub 24 / 57
25 Rozdělení řetězce split rozdělí řetězec podle zadaného podřetězce, vrací seznam částí join spojení seznamu řetězců do jednoho >>> retezec = "Holka modrooka nesedavej u potoka" >>> retezec.split() [ Holka, modrooka, nesedavej, u, potoka ] >>> retezec.split( o ) [ H, lka m, dr,, ka nesedavej u p, t, ka >>> retezec.split( ka ) [ Hol, modroo, nesedavej u poto, ] 25 / 57
26 Řetězce: další funkce find, count vyhledávání a počítání podřetězců lower, upper převod na malá/velká písmena ljust, rjust, center zarovnání textu lstrip, rstrip ořezání bílých znaků na začátku/konci 26 / 57
27 Práce se soubory připomenutí Otevírání a zavírání: f = open("mujsoubor.txt") otevření pro čtení f = open("mujsoubor.txt","w") otevření pro zápis f.close() uzavření souboru zápis pomocí with lepší praxe (ale pokročilejší, souvisí s výjimkami) Čtení a zápis: f.readline() vrátí další řádek ze souboru f.readlines() vrátí seznam všech zbývajících řádků f.write(retezec) zapíše do souboru 27 / 57
28 Příklad: Zpracování HTML vstup: HTML soubor cíl: vybrat odkazy a nadpisy ukážeme naivní řešení se soubory, reg. výrazy systémovější řešení: využití knihoven pro práci s URL zdroji, parsování HTML 28 / 57
29 Příklad: Zpracování HTML 29 / 57
30 Hledání nadpisů def najdi_nadpisy(jmeno_souboru): soubor = open(jmeno_souboru) for radek in soubor.readlines(): m = re.search(r <h(\d)>(.*?)</h\d>,radek) if m: print m.group(1), "\t", m.group(2) soubor.close() Kdy nebude fungovat korektně? 30 / 57
31 Hledání odkazů stejná základní kostra, jen jiný regulární výraz pokus č. 1: <a href="(.*)">(.*)</a> nedostatky? 31 / 57
32 Hledání odkazů stejná základní kostra, jen jiný regulární výraz pokus č. 1: <a href="(.*)">(.*)</a> nedostatky? <a href=" <a href=" <a href=" target="_blank">seznam</a> 32 / 57
33 Hledání odkazů rozšíření (stále nedostatečná): <a href="(.*?)">(.*?)</a> <a href="(.*?)".*?>(.*?)</a> * hladové hledání ( co nejvíc ) *? co nejmíň 33 / 57
34 Příklad: Jak vykrást banku? Přesněji: Jak převzít kurzy ze stránky ČNB? 34 / 57
35 Příklad: Kurzy ze stránky ČNB Základní řešení: najít řádek, na kterém jsou kurzy (začíná <tr><td>aust) rozdělit na řádky tabulky (podle </tr><tr>) hledat trojice velkých písmen a za nimi čísla převést na typ float, uložit do slovníku Nevýhody? 35 / 57
36 Příklad: Kurzy ze stránky ČNB def zjisti_kurzy(jmeno_souboru): kurzy = {} soubor = open(jmeno_souboru) for radek in soubor.readlines(): if re.match(r <tr><td>aust,radek): for radek_tab in radek.split( </tr><tr> ): m = re.search( r <td>([a-z]{3}).*right">([\d,]+)</td> radek_tab) kurzy[m.group(1)] = float(re.sub(,,.,m.group(2))) soubor.close() return kurzy 36 / 57
37 Příklad: informace o studentech Export informací z ISu (CSV soubor): 1.;50668;"Sukany, Martin";zk;"FI B-AP BcAP [sem 1, roc 2.;421714;"Veznik, Ondrej";zk;"FI B-AP SOCI [sem 2, roc 3.;564138;"Machala, David";zk;"FI B-AP BcAP [sem 1, roc 4.;43583;"Mikes, Martina";zk;"FF B-FI PLIN [sem 5, cyk 5.;81908;"Sulc, Tomas";zk;"FF B-FI PLIN [sem 5, cyk 1]" 6.;844632;"Novak, Karel";zk;"FI B-IN PSK [sem 1, roc 1] 7.;798639;"Dunickova, Dagmar";zk;"FI B-AP SOCI [sem 1, 8.;195660;"Stipsky, Tomas";zk;"FI B-AP BcAP [sem 1, roc 9.;278740;"Fojt, Roman";zk;"FI B-AP INVS [sem 3, roc 2] 10.;236293;"Zachar, Samuel";zk;"FI B-IN UMI [sem 1, roc Pozn. Příklad je mutovaný z důvodu ochrany osobních údajů. 37 / 57
38 Statistiky o studentech výpis křestních jmen (abecedně seřazený) statistika studovaných oborů 38 / 57
39 Výpis křestních jmen def krestni_jmena(jmeno_souboru): f = open(jmeno_souboru) jmena = [] for radek in f.readlines(): m = re.match(r \d+\.;\d+;"\w+, (\w+), radek) if m: jmena.append(m.group(1)) jmena.sort() print " ".join(jmena) f.close() Jiné řešení: použití split 39 / 57
40 Statistiky oborů def obory(jmeno_souboru): f = open(jmeno_souboru) vyskyty_oboru = {} for radek in f.readlines(): m = re.search(r \s(\w+) \[sem, radek) if m: obor = m.group(1) vyskyty_oboru[obor] = \ vyskyty_oboru.get(obor, 0) + 1 f.close() for obor in vyskyty_oboru.keys(): print obor, vyskyty_oboru[obor] Nedostatky: např. studenti studující více oborů. 40 / 57
41 Procvičení regulárních výrazů úloha Regulární výrazy 40 příkladů vyhledávání, nahrazování 41 / 57
42 Náhodnostní imitace vstupního textu vstup: rozsáhlý text výstup: náhodně generovaný text, který má podobné charakteristiky jako vstupní text imitace na úrovni písmen nebo slov 42 / 57
43 Náhodnostní imitace vstupního textu I špiské to pole kavodali pamas ne nebo kdy v Dejný Odm sem uvalini se zabijí s Pan stěží ře, a silobe lo v ne řečekovících blova v nadrá těly jakvěmutelaji rohnutkohonebout anej Fravinci V A pěk finé houty. zal Jírakočítencej ské žil, kddo jak a to Lorskříže si tomůžu schno mí, kto. Kterak král kočku kupoval V zemi Taškářů panoval král a zapřisáhl se velikou přísahou že bude pochválena První pán si jí ani nevšimnul zato druhý se rychle shýbl a Jůru pohladil Aha řekl sultán a bohatě obdaroval pana Lustiga koupil od něho telegram z Bombaje v Indii není o nic horší člověk nežli někdo z mých hraček Kdepak mávl Vašek rukou 43 / 57
44 Základní přístup 1 vstupní text statistiky textu 2 statistiky generování náhodného textu Co jsou vhodné statistiky? 44 / 57
45 Statistiky textu základ: frekvence písmen (slov) rozšíření: korelace mezi písmeny (slovy) příklad: pokud poslední písmeno bylo a: e velmi nepravděpodobné (méně než obvykle) l, k hodně pravděpodobná (více než obvykle) 45 / 57
46 Implementace základní frekvenční analýza datová struktura slovník písmeno frekvence rozšířená analýza slovník slovníků písmeno { písmeno frekvence } 46 / 57
47 Statistiky jmen data: četnosti jmen, příjmení podle roků, krajů,... zdroj: Ministerstvo vnitra ČR cetnost-jmen-a-prijmeni aspx XLS pro zpracování v Pythonu uložit jako CSV (comma-separated values) doporučené cvičení snadno zpracovatelné zajímavá data cvičení na vymýšlení otázek následuje několik ukázek pro inspiraci / 57
48 Jména vyučujících IB111 Radek, Zdeněk, Vít, Jan, Tomáš, Marek, Ondřej, Juraj, Jiří 48 / 57
49 Jména vyučujících IB / 57
50 První písmena jmen 50 / 57
51 Identifikace trendů U kterých jmen nejvíce roste/klesá popularita? co to vlastně znamená? jak formalizovat? 51 / 57
52 Nejdelší růst/pokles Kolik let v řadě roste popularita jména: Tobiáš 14 Viktorie, Ella, Sofie 9 Elen, Tobias 8 Kolik let v řadě klesá popularita jména: Jana 26 Martin 21 Petra 11 Zdeněk 9 52 / 57
53 Největší skok v popularitě za 10 let alespoň desetinásobný nárůst popularity: Sofie, Elen, Amálie, Ella, Nicol, Nella, Tobias pokles alespoň o 60 %: Petra, Pavlína, Martina 53 / 57
54 Počty používaných jmen 54 / 57
55 Zdroje zajímavých dat Otevřená data / Open data / 57
56 Zpracování dat seriózněji využití existujících knihoven: načítání dat ve standardních formátech: HTML, XML, JSON, CSV,... operace s daty: numpy, pandas vizualizace: matplotlib prostředí ipython 56 / 57
57 Shrnutí regulární výrazy obecně užitečný nástroj práce s textem, soubory, daty v Pythonu příklady kurzovní lístek zpracování seznamu studentů imitace textu statistiky jmen příště: obrázky 57 / 57
Regulární výrazy, práce s textem a daty. IB111 Úvod do programování skrze Python
Regulární výrazy, práce s textem a daty IB111 Úvod do programování skrze Python 2015 1 / 68 Výhled dnes: práce s textem příště: práce s obrázky příkazy pro práci s textem/obrázky ukázky na konkrétních
Využití datových struktur, práce s textem. IB111 Úvod do programování
Využití datových struktur, práce s textem IB111 Úvod do programování 2016 Výhled dnes: logické úlohy a hry, textová data příště: obrázky nástroje pro práci s textem/obrázky ilustrační příklady využití
Práce s daty. IB111 Základy programování Radek Pelánek
Práce s daty IB111 Základy programování Radek Pelánek 2017 1 / 76 Práce s daty připomenutí Jaká data budu zpracovávat? Jaká data budu potřebovat k řešení problému? Jaké operace s daty budu chtít provádět?
Programování: základní konstrukce, příklady, aplikace. IB111 Programování a algoritmizace
Programování: základní konstrukce, příklady, aplikace IB111 Programování a algoritmizace 2011 Připomenutí z minule, ze cvičení proměnné, výrazy, operace řízení výpočtu: if, for, while funkce příklady:
Regulární výrazy. Vzory
Regulární výrazy Regulární výrazy jsou určeny pro práci s textovými řetězci, jsou součástí J2SDK až od verze 1.4, v předchozích verzích je potřeba použít některou z externích knihoven, např. knihovnu ORO
Konečný automat. Jan Kybic.
Konečný automat Jan Kybic http://cmp.felk.cvut.cz/~kybic kybic@fel.cvut.cz 2016 2017 1 / 33 Konečný automat finite state machine Konečný automat = výpočetní model, primitivní počítač Řídící jednotka s
Tabulkový procesor. Základní rysy
Tabulkový procesor Tabulkový procesor je počítačový program zpracovávající data uložená v buňkách tabulky. Program umožňuje použití vzorců pro práci s daty a zobrazuje výsledné hodnoty podle vstupních
Úvod do programování 6. hodina
Úvod do programování 6. hodina RNDr. Jan Lánský, Ph.D. Katedra informatiky a matematiky Fakulta ekonomických studií Vysoká škola finanční a správní 2015 Umíme z minulé hodiny Algoritmy Třídění pole: Selection
Regulární výrazy. jemný úvod. Miloslav Brada
Regulární výrazy jemný úvod Miloslav Brada Regulární výrazy - RegExy K čemu vůbec jsou? Nástin možností Jednoduché vzory, pravidla regexpů Metaznaky Opakování Skupiny Jednoduchý příklad na závěr 2 Co RegExy
Funkce, podmíněný příkaz if-else, příkaz cyklu for
Funkce, podmíněný příkaz if-else, příkaz cyklu for Definice funkce Funkce je pojmenovaná část programu, kterou lze dále zavolat v jiné části programu. V Pythonu je definována klíčovým slovem def. Za tímto
Programování v Pythonu
ƒeské vysoké u ení technické v Praze FIT Programování v Pythonu Ji í Znamená ek P íprava studijního programu Informatika je podporována projektem nancovaným z Evropského sociálního fondu a rozpo tu hlavního
Lekce 2. Řetězce a práce s nimi. Vstup a výstup. C2184 Úvod do programování v Pythonu podzim 2016
. Vstup/výstup Lekce 2. Vstup/výstup. a práce s nimi. Vstup a výstup. C2184 Úvod do programování v Pythonu podzim 2016 Formátování Národní centrum pro výzkum biomolekul Masarykova univerzita 2.1 Char (znak)
Co jsou to regulární výrazy? Regulárními výrazy se používají ke zpracovávání textových řetězců. Vytvoříme si tzv. masku a zjišťujeme, zda jí textový řetězec vyhovuje (např. zda se skládá ze samých čísel
Vstupní požadavky, doporučení a metodické pokyny
Název modulu: Základy PHP Označení: C9 Stručná charakteristika modulu Modul je orientován na tvorbu dynamických stánek aktualizovaných podle kontextu volání. Jazyk PHP umožňuje velmi jednoduchým způsobem
DSL manuál. Ing. Jan Hranáč. 27. října 2010. V této kapitole je stručný průvodce k tvorbě v systému DrdSim a (v
DSL manuál Ing. Jan Hranáč 27. října 2010 V této kapitole je stručný průvodce k tvorbě v systému DrdSim a (v současné době krátký) seznam vestavěných funkcí systému. 1 Vytvoření nového dobrodružství Nejprve
IB111 Úvod do programování skrze Python
Vyhledávání, řazení, složitost IB111 Úvod do programování skrze Python 2012 Otrávené studny 8 studen, jedna z nich je otrávená laboratorní rozbor dokáže rozpoznat přítomnost jedu ve vodě je drahý (je časově
(a kryptografické odbočky) IB111 Úvod do programování skrze Python
Řetězce a seznamy (a kryptografické odbočky) IB111 Úvod do programování skrze Python 2013 1 / 50 Rozcvička: šifry 1 C S A R B V E K T E O A 2 C S B U J T M B W B 3 A J L B N O C E 2 / 50 Transpoziční šifry
Programování. Bc. Veronika Tomsová
Programování Bc. Veronika Tomsová Regulární výrazy Regulární výrazy slouží k porovnání a zpracovaní textu PHP podporuje syntaxi POSIX-Extended Regulární výrazy jsou velice vhodné například k ověření emailové
SPJA, cvičení 1. ipython, python, skripty. základy syntaxe: základní datové typy, řetězce. podmínky: if-elif-else, vyhodnocení logických výrazů
SPJA, cvičení 1 ipython, python, skripty základy syntaxe: základní datové typy, řetězce podmínky: if-elif-else, vyhodnocení logických výrazů cykly: for, while kolekce: seznam, n-tice, slovník funkce, list
Úvod do UNIXu. Okruh č. 4 - vi, regulární výrazy, grep a sed. Jakub Galgonek. verze r2. inspirováno materiály Davida Hokszy
Okruh č.4 Okruh č. 4 - vi, regulární výrazy, grep a sed verze 1.0.0-r2 inspirováno materiály Davida Hokszy Textové editory Okruh č.4 vi(m) prastarý textový editor (1976) dostupný v podstatě na každém UNIXovém
1. lekce. do souboru main.c uložíme následující kód a pomocí F9 ho zkompilujeme a spustíme:
1. lekce 1. Minimální program do souboru main.c uložíme následující kód a pomocí F9 ho zkompilujeme a spustíme: #include #include int main() { printf("hello world!\n"); return 0; 2.
FUNKCE 3. Autor: Mgr. Dana Kaprálová. Datum (období) tvorby: září, říjen 2013. Ročník: sedmý. Vzdělávací oblast: Informatika a výpočetní technika
FUNKCE 3 Autor: Mgr. Dana Kaprálová Datum (období) tvorby: září, říjen 2013 Ročník: sedmý Vzdělávací oblast: Informatika a výpočetní technika 1 Anotace: Žáci se seznámí se základní obsluhou tabulkového
Zdokonalování gramotnosti v oblasti ICT. Kurz MS Excel kurz 3. Inovace a modernizace studijních oborů FSpS (IMPACT) CZ.1.07/2.2.00/28.
Zdokonalování gramotnosti v oblasti ICT Kurz MS Excel kurz 3 1 Obsah Řazení dat... 3 Seřazení textu a čísel... 3 Další možné seřazení je možné podle barev, písma a ikon... 4 Filtry, rozšířené filtry...
Obsah. Předmluva 13. O autorovi 15. Poděkování 16. O odborných korektorech 17. Úvod 19
Předmluva 13 O autorovi 15 Poděkování 16 O odborných korektorech 17 Úvod 19 Co kniha popisuje 19 Co budete potřebovat 20 Komu je kniha určena 20 Styly 21 Zpětná vazba od čtenářů 22 Errata 22 KAPITOLA 1
Programování v Pythonu
ƒeské vysoké u ení technické v Praze FIT Programování v Pythonu Ji í Znamená ek P íprava studijního programu Informatika je podporována projektem nancovaným z Evropského sociálního fondu a rozpo tu hlavního
KIV/ZIS cvičení 5. Tomáš Potužák
KIV/ZIS cvičení 5 Tomáš Potužák Úvod do SQL (1) SQL (Structured Query Language) je standardizovaný strukturovaný dotazovací jazyk pro práci s databází Veškeré operace v databázi se dají provádět pomocí
IV122 Matematika a programování Úvod kurzu. Radek Pelánek
IV122 Matematika a programování Úvod kurzu Radek Pelánek Cíle předmětu Lepší pochopení matematických pojmů a metod skrze praktické programování. Procvičení programátorských schopností; trénink přechodu
HROMADNÉ ÚPRAVY NAJÍT A NAHRADIT
HROMADNÉ ÚPRAVY NAJÍT A NAHRADIT Funkce Najít a nahradit slouží k rychlému vyhledávání určitých slov a jejich nahrazování jinými slovy. Lze hledat i určité varianty slov a nahrazovat je buď hromadně (všechny
Úvod do databázových systémů
Vysoká škola báňská Technická univerzita Ostrava Fakulta elektrotechniky a informatiky Úvod do databázových systémů Cvičení 3 Ing. Petr Lukáš petr.lukas@vsb.cz Ostrava, 2014 Opakování 4 fáze vytváření
Scrapping stránek prakticky: Dívka dne na TN.cz
Scrapping stránek prakticky: Dívka dne na TN.cz Obsah Scrapping stránek prakticky: Dívka dne na TN.cz...1 Praktický příklad scrapping-u v Python-u...1 Analýza galerie Dívky dne...2 Krok 1: zjištění URL
1. lekce. do souboru main.c uložíme následující kód a pomocí F9 ho zkompilujeme a spustíme:
1. lekce 1. Minimální program do souboru main.c uložíme následující kód a pomocí F9 ho zkompilujeme a spustíme: #include #include int main() { printf("hello world!\n"); return 0; 2.
Úvod Informace o prostředí Práce se soubory Regulární výrazy Konec. Programování v C# Soubory a regulární výrazy. Petr Vaněček 1 / 27
Programování v C# Soubory a regulární výrazy Petr Vaněček 1 / 27 Obsah přednášky Informace o prostředí Práce se soubory Regulární výrazy 2 / 27 Zprostředkování informací Třída System.Environment Poskytuje
Databáze prodejců. Tlačítka. Vytvoří kartu nového prodejce (Alt+N); Změní vybraného prodejce Uloží nového prodejce nebo změnu (Alt+U);
Databáze prodejců Tlačítka Vytvoří kartu nového prodejce (Alt+N); Změní vybraného prodejce (Alt+E); Uloží nového prodejce nebo změnu (Alt+U); Při zakládání nového prodejce zadejte jeho číslo (musí to být
Praktické tipy, programovací jazyky. IB111 Základy programování Radek Pelánek
Praktické tipy, programovací jazyky IB111 Základy programování Radek Pelánek 2017 1 / 76 Dnešní přednáška shrnutí základů vývojová prostředí, editory správa verzí knihovny, praktický vývoj v Pythonu regulární
Čtvrtek 8. prosince. Pascal - opakování základů. Struktura programu:
Čtvrtek 8 prosince Pascal - opakování základů Struktura programu: 1 hlavička obsahuje název programu, použité programové jednotky (knihovny), definice konstant, deklarace proměnných, všechny použité procedury
Penframe ESHOP. Basic Standard Pro. 34 900 Kč 69 900 Kč 99 900 Kč. Grafický návrh. Redesign šablon: barevnost, hlavička, logo, grafické prvky stránky
Grafický návrh Redesign šablon: barevnost, hlavička, logo, grafické prvky stránky Tvorba individuálního grafického návrhu na přání klienta Základní moduly a funkčnost aplikace Počet jazykových mutací 1
KAPITOLA 5. Práce s textovými řetězci. V této kapitole najdete: Deklarace textových řetězců Operace s řetězci Ukázkový kód pro operace s řetězci
KAPITOLA 5 Práce s textovými řetězci V této kapitole najdete: Deklarace textových řetězců Operace s řetězci Ukázkový kód pro operace s řetězci 94 Kapitola 5: Práce s textovými řetězci Slova jsou textovými
IB111 Úvod do programování skrze Python
Vyhledávání, řazení, složitost IB111 Úvod do programování skrze Python 2014 1 / 48 Otrávené studny 8 studen, jedna z nich je otrávená laboratorní rozbor dokáže rozpoznat přítomnost jedu ve vodě je drahý
PROGRAMOVÁNÍ V SHELLU
PROGRAMOVÁNÍ V SHELLU Prostředí, jazyk, zdrojový kód chceme-li posloupnost jistých příkazů používat opakovaně, případně z různých míst adresářové struktury, můžeme tuto posloupnost uložit souboru, který
Da D to t v o é v ty t py IB111: Datové typy
Datové typy IB111: Datové typy Data a algoritmizace jaká data potřebuji pro vyřešení problému? jak budu data reprezentovat? jaké operaci s nimi potřebuji provádět? Navržení práce s daty je velice důležité
III/2 Inovace a zkvalitnění výuky prostřednictvím ICT
Číslo a název šablony Číslo didaktického materiálu Druh didaktického materiálu Autor Jazyk Téma sady didaktických materiálů Téma didaktického materiálu Vyučovací předmět Cílová skupina (ročník) Úroveň
Standardní algoritmy vyhledávací.
Standardní algoritmy vyhledávací. Vyhledávací algoritmy v C++ nám umožňují vyhledávat prvky v datových kontejnerech podle různých kritérií. Také se podíváme na vyhledávání metodou půlením intervalu (binární
VISUAL BASIC. Práce se soubory
VISUAL BASIC Práce se soubory Práce se soubory 1/2 2 Vstupní data pro programy bývají uloženy do souborů Vstupy pro výpočet, nastavení vzhledu aplikace Výsledky práce programu je potřeba uchovat uložit
Algoritmizace a programování
Algoritmizace a programování Výrazy Operátory Výrazy Verze pro akademický rok 2012/2013 1 Operace, operátory Unární jeden operand, operátor se zapisuje ve většině případů před operand, v některých případech
Programování v jazyce JavaScript
Programování v jazyce JavaScript Katedra softwarového inženýrství Fakulta informačních technologií České vysoké učení technické v Praze Pavel Štěpán, 2011 Operátory a příkazy BI-JSC Evropský sociální fond
Regulární výrazy. Definice Množina regulárních výrazů nad abecedou Σ, označovaná RE(Σ), je definována induktivně takto:
IB102 Automaty, gramatiky a složitost, 6. 10. 2014 1/29 Regulární výrazy Definice 2.58. Množina regulárních výrazů nad abecedou Σ, označovaná RE(Σ), je definována induktivně takto: 1 ε, a a pro každé a
NPRG030 Programování I, 2017/18 1 / :22:16
NPRG030 Programování I, 2017/18 1 / 26 20. 10. 2017 11:22:16 Ordinální typy standardní: integer, char, boolean Vlastnosti ordinálních typů: 1. hodnot je konečný počet a hodnoty jsou uspořádány 2. ke každé
Semestrální úloha 1 z předmětu Programovací jazyk C. Textový merge. Student:
Semestrální úloha 1 z předmětu Programovací jazyk C Textový merge Napište program, který spojí dva textové soubory. První soubor je datový, obsahuje databázi, tj. první řádek představuje seznam sloupců
Algoritmizace Dynamické programování. Jiří Vyskočil, Marko Genyg-Berezovskyj 2010
Dynamické programování Jiří Vyskočil, Marko Genyg-Berezovskyj 2010 Rozděl a panuj (divide-and-conquer) Rozděl (Divide): Rozděl problém na několik podproblémů tak, aby tyto podproblémy odpovídaly původnímu
PHP tutoriál (základy PHP snadno a rychle)
PHP tutoriál (základy PHP snadno a rychle) Druhá, vylepšená offline verze. Připravil Štěpán Mátl, http://khamos.wz.cz Chceš se naučit základy PHP? V tom případě si prostuduj tento rychlý průvodce. Nejdříve
Popis programu EnicomD
Popis programu EnicomD Pomocí programu ENICOM D lze konfigurovat výstup RS 232 přijímačů Rx1 DIN/DATA a Rx1 DATA (přidělovat textové řetězce k jednotlivým vysílačům resp. tlačítkům a nastavovat parametry
Tabulková data. budeme pracovat s CSV soubory položky oddělené středníkem, např.
Tabulková data budeme pracovat s CSV soubory položky oddělené středníkem, např. Číslo zákazníka;příjmení;jméno;datum narození 17;Novotná;Bohdana;25.11.1982 22;Kender;David;24.12.1986 29;Čihák;Jan;18.3.1969
Databázové systémy. Cvičení 6: SQL
Databázové systémy Cvičení 6: SQL Co je SQL? SQL = Structured Query Language SQL je standardním (ANSI, ISO) textovým počítačovým jazykem SQL umožňuje jednoduchým způsobem přistupovat k datům v databázi
Naproti tomu gramatika je vlastně soupis pravidel, jak
1 Kapitola 1 Úvod V přednášce se zaměříme hlavně na konečný popis obecně nekonečných množin řetězců symbolů dané množiny A. Prvkům množiny A budeme říkat písmena, řetězcům (konečným posloupnostem) písmen
Vyučovací hodina. 1vyučovací hodina: 2vyučovací hodiny: Opakování z minulé hodiny. Procvičení nové látky
Vyučovací hodina 1vyučovací hodina: Opakování z minulé hodiny Nová látka Procvičení nové látky Shrnutí 5 min 20 min 15 min 5 min 2vyučovací hodiny: Opakování z minulé hodiny Nová látka Procvičení nové
Regulární výrazy. Filtry grep, sed a awk.
Přednáška 5 Regulární výrazy. Filtry grep, sed a awk. Katedra počítačových systémů FIT, České vysoké učení technické v Praze Jan Trdlička, 2011 Příprava studijního programu Informatika je podporována projektem
Úvod do databázových systémů
Vysoká škola báňská Technická univerzita Ostrava Fakulta elektrotechniky a informatiky Katedra informatiky Database Research Group Úvod do databázových systémů Cvičení 3 Ing. Petr Lukáš petr.lukas@vsb.cz
Formální jazyky a gramatiky Teorie programovacích jazyků
Formální jazyky a gramatiky Teorie programovacích jazyků doc. Ing. Jiří Rybička, Dr. ústav informatiky PEF MENDELU v Brně rybicka@mendelu.cz Připomenutí základních pojmů ABECEDA jazyk je libovolná podmnožina
Parsování v Haskellu, knihovna Parsec
Parsování v Haskellu, knihovna Parsec IB016 Seminář z funkcionálního programování Vladimír Štill, Martin Ukrop Fakulta informatiky, Masarykova univerzita Jaro 2016 IB016: Cvičení 09 Jaro 2016 1 / 12 Regulární
Vytvořil Institut biostatistiky a analýz, Masarykova univerzita J. Jarkovský, L. Dušek, M. Cvanová. 5. Statistica
Vytvořil Institut biostatistiky a analýz, Masarykova univerzita J. Jarkovský, L. Dušek, M. Cvanová 5. Statistica StatSoft, Inc., http://www.statsoft.com, http://www.statsoft.cz. Verze pro Mac i PC, dostupná
Základní příkazy UNIXu (Linuxu)
Základní příkazy UNIXu (Linuxu) Ostatní clear smazání obrazovky man nápověda k příkazům (zkus man man) Ovládání příkazu man PgUp, b stránka vzhůru PgDn, mezerník stránka dolů šipky nahoru a dolů pohyb
1. Téma 03 - Rozhodování
1. Téma 03 - Rozhodování Cíl látky Seznámit se a prakticky si vyzkoušet zápis rozhodování v jazyce Java 1.1. Úvod Jednou z nejčastěji používanou konstrukcí při programování je rozhodování. Právě této problematice
ALGORITMIZACE A PROGRAMOVÁNÍ
Metodický list č. 1 Algoritmus a jeho implementace počítačovým programem Základním cílem tohoto tematického celku je vysvětlení pojmů algoritmus a programová implementace algoritmu. Dále je cílem seznámení
5 Přehled operátorů, příkazy, přetypování
5 Přehled operátorů, příkazy, přetypování Studijní cíl Tento studijní blok má za cíl pokračovat v základních prvcích jazyka Java. Konkrétně budou uvedeny detaily týkající se operátorů. Doba nutná k nastudování
Druhy souborů. textové. binární. nestrukturované txt strukturované - ini, xml, csv. veřejné bmp, jpg, wav proprietární docx, cdr, psd
Soubory Druhy souborů textové nestrukturované txt strukturované - ini, xml, csv binární veřejné bmp, jpg, wav proprietární docx, cdr, psd Základy zápisu using System.IO; nutné pro odkázání na jmenný prostor,
LinuxDays 2017 Ondřej Guth GNU grep LD 17 1 / 14
Používáte GNU grep? A víte, jak funguje uvnitř? Ondřej Guth ondrej.guth@fit.cvut.cz LinuxDays 2017 Ondřej Guth GNU grep LD 17 1 / 14 1 Úvod 2 Přehled zpracování vstupu 3 Obyčejný řetězec jako regulární
1 Webový server, instalace PHP a MySQL 13
Úvod 11 1 Webový server, instalace PHP a MySQL 13 Princip funkce webové aplikace 13 PHP 14 Principy tvorby a správy webového serveru a vývojářského počítače 14 Co je nezbytné k instalaci místního vývojářského
Vlastnosti regulárních jazyků
Vlastnosti regulárních jazyků Podobně jako u dalších tříd jazyků budeme nyní zkoumat následující vlastnosti regulárních jazyků: vlastnosti strukturální, vlastnosti uzávěrové a rozhodnutelné problémy pro
- znakové konstanty v apostrofech, např. a, +, (znak mezera) - proměnná zabírá 1 byte, obsahuje kód příslušného znaku
Znaky - standardní typ char var Z, W: char; - znakové konstanty v apostrofech, např. a, +, (znak mezera) - proměnná zabírá 1 byte, obsahuje kód příslušného znaku - v TP (často i jinde) se používá kódová
Výrazy a operátory. Operátory Unární - unární a unární + Např.: a +b
Výrazy a operátory i = 2 i = 2; to je výraz to je příkaz 4. Operátory Unární - unární a unární + Např.: +5-5 -8.345 -a +b - unární ++ - inkrement - zvýší hodnotu proměnné o 1 - unární -- - dekrement -
IB111 Základy programování Radek Pelánek
Proměnné, paměť, soubory IB111 Základy programování Radek Pelánek 2017 1 / 54 Rozcvička I a = [3, 1, 7] print(sorted(a)) print(a) b = [4, 3, 1] print(b.sort()) print(b) 2 / 54 Rozcvička II a = ["magic"]
Maturitní otázky z předmětu PROGRAMOVÁNÍ
Wichterlovo gymnázium, Ostrava-Poruba, příspěvková organizace Maturitní otázky z předmětu PROGRAMOVÁNÍ 1. Algoritmus a jeho vlastnosti algoritmus a jeho vlastnosti, formy zápisu algoritmu ověřování správnosti
Automatická segmentace slov s pomocí nástroje Affisix. Michal@Hrusecky.net, Hlavacova@ufal.mff.cuni.cz
Automatická segmentace slov s pomocí nástroje Affisix Michal Hrušecký, Jaroslava Hlaváčová Michal@Hrusecky.net, Hlavacova@ufal.mff.cuni.cz Motivace Při zpracování přirozeného jazyka nikdy nemůžeme mít
Poslední aktualizace: 14. října 2011
Lexikální analýza Překladače, přednáška č. 2 Šárka Vavrečková Ústav informatiky, FPF SU Opava sarka.vavreckova@fpf.slu.cz http://fpf.slu.cz/ vav10ui Poslední aktualizace: 14. října 2011 Symboly Co je to
Základní principy vyhledávání firem
Základní principy vyhledávání firem Vyhledávat informace v databázi lze několika způsoby. Základní způsob používá postupné kroky, kdy otevíráme tzv. slovníky, z nichž vybíráme požadované hodnoty, například
Přednáška 7. Celočíselná aritmetika. Návratový kód. Příkazy pro větvení výpočtu. Cykly. Předčasné ukončení cyklu.
Přednáška 7 Celočíselná aritmetika. Návratový kód. Příkazy pro větvení výpočtu. Cykly. Předčasné ukončení cyklu. 1 Příkaz expr výraz Celočíselná aritmetika I Zašle na standardní výstup vyhodnocení výrazu
Výčtový typ strana 67
Výčtový typ strana 67 8. Výčtový typ V této kapitole si ukážeme, jak implementovat v Javě statické seznamy konstant (hodnot). Příkladem mohou být dny v týdnu, měsíce v roce, planety obíhající kolem slunce
Faculty of Nuclear Sciences and Physical Engineering Czech Technical University in Prague
1 / 23 Faculty of Nuclear Sciences and Physical Engineering Czech Technical University in Prague 2 / 23 biologové často potřebují najít často se opakující sekvence DNA tyto sekvence bývají relativně krátké,
Hledání v textu algoritmem Boyer Moore
Zápočtová práce z Algoritmů a Datových Struktur II (NTIN061) Hledání v textu algoritmem Boyer Moore David Pěgřímek http://davpe.net Algoritmus Boyer Moore[1] slouží k vyhledání vzoru V v zadaném textu
Informatika pro moderní fyziky (11) web scraping; API; zadání zápočtových úloh
Informatika pro moderní fyziky (11) web scraping; API; zadání zápočtových úloh František HAVLŮJ e-mail: haf@ujv.cz ÚJV Řež oddělení Reaktorové fyziky a podpory palivového cyklu akademický rok 2014/2015
Přednáška 4. Regulární výrazy. Filtry grep, sed a awk. Úvod do Operačních Systémů Přednáška 4
1 Přednáška 4 Regulární výrazy. Filtry grep, sed a awk. 2 grep grep [přepínače] vzor [soubory] Implicitně vypíše na standardní výstup řádky, které obsahují zadaný vzor. Vzor může být definován základním
grep a regulární výrazy
grep a regulární výrazy Josef Hajas hajasj1@fel.cvut.cz http://cs.felk.cvut.cz/~hajasj1/unix/ Vysázeno v LAT E Xu p.1/1 Co nás čeká grep: K čemu slouží? Jak používat? nejpoužívanější přepínače grepu regulární
Zadání druhého zápočtového projektu Základy algoritmizace, 2005
Zadání druhého zápočtového projektu Základy algoritmizace, 2005 Jiří Dvorský 2 května 2006 Obecné pokyny Celkem je k dispozici 8 zadání příkladů Každý student obdrží jedno zadání Vzhledem k tomu, že odpadly
Skripty - úvod. Linux - skripty 2
Linux - skripty Autorem materiálu a všech jeho částí, není-li uvedeno jinak, je Ing. Libor Otáhalík. Dostupné z Metodického portálu www.rvp.cz, ISSN: 1802-4785. Provozuje Národní ústav pro vzdělávání,
Gymnázium a Střední odborná škola, Rokycany, Mládežníků 1115
Gymnázium a Střední odborná škola, Rokycany, Mládežníků 1115 Číslo projektu: Číslo šablony: Název materiálu: Ročník: Identifikace materiálu: Jméno autora: Předmět: Tématický celek: CZ.1.07/1.5.00/34.0410
for (i = 0, j = 5; i < 10; i++) { // tělo cyklu }
5. Operátor čárka, - slouží k jistému určení pořadí vykonání dvou příkazů - oddělím-li čárkou dva příkazy, je jisté, že ten první bude vykonán dříve než příkaz druhý. Např.: i = 5; j = 8; - po překladu
Kolekce, cyklus foreach
Kolekce, cyklus foreach Jen informativně Kolekce = seskupení prvků (objektů) Jednu již známe pole (Array) Kolekce v C# = třída, která implementuje IEnumerable (ICollection) Cyklus foreach ArrayList pro
24 Uživatelské výběry
24 Uživatelské výběry Uživatelský modul Uživatelské výběry slouží k vytváření, správě a následnému používání tématicky seskupených osob a organizací včetně jejich kontaktních údajů. Modul umožňuje hromadnou
A7B38UOS Úvod do operačních systémů. 6. Cvičení. Příkazy sed a awk
A7B38UOS Úvod do operačních systémů 6. Cvičení Příkazy sed a awk sed sed [přepínače] 'příkaz' [soubory] sed [přepínače] -f skript [soubory] Stream editor - edituje neinteraktivně jeden nebo více souborů.
Co je nového v systémech DUNA DE, DUNA ÚČTO, DUNA OBCHOD 2013,1.22
Co je nového v systémech DUNA DE, DUNA ÚČTO, DUNA OBCHOD 2013,1.22 Nastavení základní konfigurace Údaje o firmě záložka Finanční úřad změny v souvislosti se změnou číselníku Finančních úřadů, proveďte
Programování v C++, 2. cvičení
Programování v C++, 2. cvičení 1 1 Fakulta jaderná a fyzikálně inženýrská České vysoké učení technické v Praze Zimní semestr 2018/2019 Přehled 1 Operátory new a delete 2 3 Operátory new a delete minule
Programování v C++ 1, 5. cvičení
Programování v C++ 1, 5. cvičení konstruktory, nevirtuální dědění 1 1 Fakulta jaderná a fyzikálně inženýrská České vysoké učení technické v Praze Zimní semestr 2018/2019 Přehled 1 2 3 Shrnutí minule procvičené
CODEWEEK 2014 Rozvoj algoritmického myšlení nejen pomocí programu MS Excel. Michaela Ševečková
CODEWEEK 2014 Rozvoj algoritmického myšlení nejen pomocí programu MS Excel Michaela Ševečková Rozvoj technického myšlení nejmenších dětí práce s předměty charakteristika, diferenciace (hledání rozdílů),
Pole a Funkce. Úvod do programování 1 Tomáš Kühr
Pole a Funkce Úvod do programování 1 Tomáš Kühr (Jednorozměrné) pole u Datová struktura u Lineární u Homogenní = prvky stejného datového typu u Statická = předem určený počet prvků u Pole umožňuje pohodlně
ŘÍDÍCÍ STRUKTURY - PODMÍNKY
ŘÍDÍCÍ STRUKTURY - PODMÍNKY Pokusíme se rozvětvit sktipt v Bashi ŘÍDÍCÍ STRUKTURY - PODMÍNKY V této lekci budeme probírat podmínkové, tj., které nám pomohou rozvětvit skript a provádět určité pouze při
(a kryptografické odbočky) IB111 Úvod do programování skrze Python
Řetězce a seznamy (a kryptografické odbočky) IB111 Úvod do programování skrze Python 2014 1 / 56 Rozcvička: šifry 1 C S A R B V E K T E O A 2 A J L B N O C E 3 C S B U J T M B W B 2 / 56 Transpoziční šifry
Metodický koncept k efektivní podpoře klíčových odborných kompetencí s využitím cizího jazyka ATCZ62 - CLIL jako výuková strategie na vysoké škole
Pattern matching Metodický koncept k efektivní podpoře klíčových odborných kompetencí s využitím cizího jazyka ATCZ62 - CI jako výuková strategie na vysoké škole Pattern matching porovnávání vzorů Hledání
Vyhledávání na portálu Knihovny.cz
Inforum 2017 Vyhledávání na portálu Knihovny.cz Petr Žabička, Václav Rosecký, Petra Žabičková Moravská zemská knihovna v Brně Obsah Co indexuje portál Knihovny.cz Rozšíření o centrální index Hledání v
1 ZÁKLADNÍ POPIS 2 3 DOPORUČENÁ NASTAVENÍ ÚČETNÍHO SYSTÉMU 6 4 TRANSAKČNÍ SOUBOR 6 5 PŘÍKLAD SOUBORU 6
FORMÁT ABO/KPC OBSAH 1 ZÁKLADNÍ POPIS 2 2 STRUKTURA ZÁZNAMU UHL1 2 2.1 Struktura hlavičky účetního souboru výpisu záznam 074 3 2.2 Struktura hlavičky skupiny 3 2.3 Struktura účetní položky 4 3 DOPORUČENÁ