HALLOWEEN JE TADY: Získej 66 % extra kreditů zdarma při nákupu od 1199 kreditů s promo kódem NEBOJSEIT66. Zjisti více:
NOVINKA: Začni v IT jako webmaster s komplexním akreditovaným online kurzem Tvůrce WWW stránek. Zjisti více:

Diskuze – Lekce 15 - Textové řetězce v Pythonu do třetice - Split a Join

Zpět

Upozorňujeme, že diskuze pod našimi online kurzy jsou nemoderované a primárně slouží k získávání zpětné vazby pro budoucí vylepšení kurzů. Pro studenty našich rekvalifikačních kurzů nabízíme možnost přímého kontaktu s lektory a studijním referentem pro osobní konzultace a podporu v rámci jejich studia. Toto je exkluzivní služba, která zajišťuje kvalitní a cílenou pomoc v případě jakýchkoli dotazů nebo projektů.

Komentáře
Avatar
DarkCoder
Člen
Avatar
Odpovídá na Michaela Zahradníková
DarkCoder:12. srpna 16:06

Pokud Ti jde o pochopení funkcí split() a join() bez omáčky, podívej na následující příklad.

text = "jablko-banán-hruška"
print(text)               # Výstup: jablko-banán-hruška

# split vrací list
tokeny = text.split("-")  # ['jablko', 'banán', 'hruška']

# Práce se seznamem
print(tokeny[0])          # přístup přes index → 'Výstup: jablko'
tokeny.append("meloun")   # přidání nového prvku
tokeny.remove("banán")    # odebrání podle hodnoty
tokeny.sort()             # seřazení

for token in tokeny:      # Výstup: hruška jablko meloun
    print(token, end=' ')
print()

text_2 = "-".join(tokeny)
print(text_2)             # Výstup: hruška-jablko-meloun
Odpovědět
12. srpna 16:06
"I ta nejlepší poučka postrádá na významu, není-li patřičně předána." - DarkCoder
Avatar
DarkCoder
Člen
Avatar
DarkCoder:12. srpna 16:25

K výkladu:

Proč nesdělíte jasně že funkce split vrací seznam (list)? Čtenářům to pak bude mnohem srozumitelnější.

Stejně tak když tokenizujete znaky pomocí split, proč nezvolíte funkci bez parametrů která rozděluje podle všech bílých znaků oproti funkci s argumentem mezery.

A nakonec řízené toku programu podle vyhodnocení výjimky není vhodné. Mnohem lepší je otestovat přítomnost znaku a podle toho pokračovat dál.

# Morseova abeceda – znaky
abecedni_znaky = "abcdefghijklmnopqrstuvwxyz"
morseovy_znaky = [".-", "-...", "-.-.", "-..", ".", "..-.", "--.", "....",
                  "..", ".---", "-.-", ".-..", "--", "-.", "---", ".--.", "--.-", ".-.",
                  "...", "-", "..-", "...-", ".--", "-..-", "-.--", "--.."]

# Vstupní zakódovaná zpráva
sifrovana_zprava = ".-.. . --- -.   .- .-. -.. ---"
print(f"Původní zpráva: {sifrovana_zprava}")

# Rozdělení na Morseovy znaky
znaky = sifrovana_zprava.split()
# znaky = sifrovana_zprava.split(" ")

# Výsledek
zprava = ""

# Dekódování
for morseuv_znak in znaky:
    if morseuv_znak in morseovy_znaky:
        index = morseovy_znaky.index(morseuv_znak)
        zprava += abecedni_znaky[index]
    else:
        zprava += "?"  # Neznámý znak

# Výpis výsledku
print(f"Dekódovaná zpráva: {zprava}")

Zájemci o rozdíl mezi bezparametrovým a parametrových splitem, nechť si zakomentují původní verzi o použijí druhou.

Odpovědět
12. srpna 16:25
"I ta nejlepší poučka postrádá na významu, není-li patřičně předána." - DarkCoder
Avatar
Kristýna Černošková:18. září 19:16

Potřebovala bych podrobnější popis k jednotlivým příkladům a víc příkladů.

 
Odpovědět
18. září 19:16
Avatar
DarkCoder
Člen
Avatar
Odpovídá na Kristýna Černošková
DarkCoder:19. září 9:08

Zadání:

Máš daný jeden řetězec obsahující více IP adres oddělených čárkou. Každá IP adresa je ve formátu xxx.xxx.xxx.xxx, tedy čtyři části (oktet) oddělené tečkami.

Tvým úkolem je na jeden řádek vypsat poslední oktety od sebe oddělené mezerou.

vstup (předem daný v kódu):

ip_adresy = "192.168.1.1,10.0.0.254,172.16.0.3"

výstup:

1 254 3

Postup:

Rozdělit řetězec podle čárek na jednotlivé IP adresy.
Každou IP adresu rozdělit na části podle teček.
Z každé IP adresy získat poslední (čtvrtý) oktet pomocí kladného indexu.
Všechny získané části uložit do seznamu.
Výsledný seznam převést na jeden řetězec, kde budou hodnoty oddělené mezerou.
Výsledný řetězec vytisknout.

Pokud některá IP adresa nemá správný formát (nemá 4 části), místo posledního oktetu ulož text "CHYBA".

Řešení:

# Vstupní řetězec IP adres
ip_adresy = "192.168.1.1,10.0.0.254,172.16.0.3"

# Rozdělení podle čárek na jednotlivé IP adresy
ip_list = ip_adresy.split(',')

# Seznam pro uložení posledních částí
posledni_casti = []

# Pro každou IP adresu:
for ip in ip_list:
    parts = ip.split('.')  # rozdělení podle teček
    if len(parts) == 4:     # kontrola, že IP má správný formát
        posledni_casti.append(parts[3])  # přístup přes kladný index
    else:
        posledni_casti.append("CHYBA")  # ošetření neplatného formátu

# Výpis na jeden řádek
print(" ".join(posledni_casti))
Odpovědět
19. září 9:08
"I ta nejlepší poučka postrádá na významu, není-li patřičně předána." - DarkCoder
Děláme co je v našich silách, aby byly zdejší diskuze co nejkvalitnější. Proto do nich také mohou přispívat pouze registrovaní členové. Pro zapojení do diskuze se přihlas. Pokud ještě nemáš účet, zaregistruj se, je to zdarma.

Zobrazeno 4 zpráv z 34.