Umgang mit der Shell Übungen: Unterschied zwischen den Versionen

Aus Xinux Wiki
Zur Navigation springen Zur Suche springen
Zeile 2: Zeile 2:
 
'''Übung:'''
 
'''Übung:'''
 
* Finde alle Zeilen, die das Wort "User" enthalten.
 
* Finde alle Zeilen, die das Wort "User" enthalten.
  <pre>grep "User" testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
 +
! Lösung
 +
|-
 +
| <pre>grep "User" testfile.txt</pre>
 +
|}
 
* Suche Zeilen, die mit "Error" beginnen.
 
* Suche Zeilen, die mit "Error" beginnen.
  <pre>grep "^Error" testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
 +
! Lösung
 +
|-
 +
| <pre>grep "^Error" testfile.txt</pre>
 +
|}
 
* Finde alle Zeilen, die '''nicht''' "Success" enthalten.
 
* Finde alle Zeilen, die '''nicht''' "Success" enthalten.
  <pre>grep -v "Success" testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
* Suche nach Zeilen, die Zahlen enthalten.
+
! Lösung
  <pre>grep "[0-9]" testfile.txt</pre>
+
|-
 +
| <pre>grep -v "Success" testfile.txt</pre>
 +
|}
  
 
----
 
----
Zeile 15: Zeile 25:
 
'''Übung:'''
 
'''Übung:'''
 
* Zähle die Anzahl der Zeilen in der Datei.
 
* Zähle die Anzahl der Zeilen in der Datei.
  <pre>wc -l testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
 +
! Lösung
 +
|-
 +
| <pre>wc -l testfile.txt</pre>
 +
|}
 
* Zähle die Wörter in der Datei.
 
* Zähle die Wörter in der Datei.
  <pre>wc -w testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
* Zähle die Zeichen in der Datei.
+
! Lösung
  <pre>wc -m testfile.txt</pre>
+
|-
 +
| <pre>wc -w testfile.txt</pre>
 +
|}
  
 
----
 
----
Zeile 26: Zeile 42:
 
'''Übung:'''
 
'''Übung:'''
 
* Ersetze alle Kleinbuchstaben durch Großbuchstaben.
 
* Ersetze alle Kleinbuchstaben durch Großbuchstaben.
  <pre>tr 'a-z' 'A-Z' < testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
 +
! Lösung
 +
|-
 +
| <pre>tr 'a-z' 'A-Z' < testfile.txt</pre>
 +
|}
 
* Entferne alle Ziffern.
 
* Entferne alle Ziffern.
  <pre>tr -d '0-9' < testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
* Ersetze Leerzeichen durch Unterstriche.
+
! Lösung
  <pre>tr ' ' '_' < testfile.txt</pre>
+
|-
 +
| <pre>tr -d '0-9' < testfile.txt</pre>
 +
|}
  
 
----
 
----
Zeile 37: Zeile 59:
 
'''Übung:'''
 
'''Übung:'''
 
* Extrahiere die erste Spalte aus Zeilen mit "User".
 
* Extrahiere die erste Spalte aus Zeilen mit "User".
  <pre>grep "User" testfile.txt | cut -d' ' -f2</pre>
+
{| class="mw-collapsible mw-collapsed"
 +
! Lösung
 +
|-
 +
| <pre>grep "User" testfile.txt | cut -d' ' -f2</pre>
 +
|}
 
* Schneide die ersten 10 Zeichen jeder Zeile ab.
 
* Schneide die ersten 10 Zeichen jeder Zeile ab.
  <pre>cut -c1-10 testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
* Extrahiere die Altersangaben aus den "User"-Zeilen.
+
! Lösung
  <pre>grep "User" testfile.txt | cut -d' ' -f4</pre>
+
|-
 +
| <pre>cut -c1-10 testfile.txt</pre>
 +
|}
  
 
----
 
----
Zeile 48: Zeile 76:
 
'''Übung:'''
 
'''Übung:'''
 
* Ersetze "Alice" durch "Alicia".
 
* Ersetze "Alice" durch "Alicia".
  <pre>sed 's/Alice/Alicia/' testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
 +
! Lösung
 +
|-
 +
| <pre>sed 's/Alice/Alicia/' testfile.txt</pre>
 +
|}
 
* Lösche alle Zeilen, die mit # beginnen.
 
* Lösche alle Zeilen, die mit # beginnen.
  <pre>sed '/^#/d' testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
* Ersetze "Success" durch "✔ DONE" in der Datei.
+
! Lösung
  <pre>sed 's/Success/✔ DONE/' testfile.txt</pre>
+
|-
 +
| <pre>sed '/^#/d' testfile.txt</pre>
 +
|}
  
 
----
 
----
Zeile 59: Zeile 93:
 
'''Übung:'''
 
'''Übung:'''
 
* Sortiere die Datei alphabetisch.
 
* Sortiere die Datei alphabetisch.
  <pre>sort testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
 +
! Lösung
 +
|-
 +
| <pre>sort testfile.txt</pre>
 +
|}
 
* Sortiere rückwärts.
 
* Sortiere rückwärts.
  <pre>sort -r testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
* Sortiere nach der zweiten Spalte (Alter der User).
+
! Lösung
  <pre>grep "User" testfile.txt | sort -k4 -n</pre>
+
|-
 +
| <pre>sort -r testfile.txt</pre>
 +
|}
  
 
----
 
----
Zeile 70: Zeile 110:
 
'''Übung:'''
 
'''Übung:'''
 
* Zeige alle Dateien im aktuellen Verzeichnis, die mit "t" beginnen.
 
* Zeige alle Dateien im aktuellen Verzeichnis, die mit "t" beginnen.
  <pre>ls t*</pre>
+
{| class="mw-collapsible mw-collapsed"
 +
! Lösung
 +
|-
 +
| <pre>ls t*</pre>
 +
|}
 
* Zeige Dateien an, die genau vier Zeichen lang sind.
 
* Zeige Dateien an, die genau vier Zeichen lang sind.
  <pre>ls ????</pre>
+
{| class="mw-collapsible mw-collapsed"
* Finde Dateien, die auf .txt oder .log enden.
+
! Lösung
  <pre>ls *.{txt,log}</pre>
+
|-
 +
| <pre>ls ????</pre>
 +
|}
  
 
----
 
----
Zeile 81: Zeile 127:
 
'''Übung:'''
 
'''Übung:'''
 
* Finde Telefonnummern (Muster: 123-456-7890).
 
* Finde Telefonnummern (Muster: 123-456-7890).
  <pre>grep -E "[0-9]{3}-[0-9]{3}-[0-9]{4}" testfile.txt</pre>
+
{| class="mw-collapsible mw-collapsed"
* Finde Zeilen mit einer Kombination aus Groß- und Kleinbuchstaben.
+
! Lösung
  <pre>grep -E "[A-Z][a-z]+" testfile.txt</pre>
+
|-
* Suche nach Wörtern, die mit "a" oder "b" beginnen.
+
| <pre>grep -E "[0-9]{3}-[0-9]{3}-[0-9]{4}" testfile.txt</pre>
  <pre>grep -E "^[ab]" testfile.txt</pre>
+
|}
  
 
----
 
----
Zeile 92: Zeile 138:
 
'''Übung:'''
 
'''Übung:'''
 
* Kombiniere grep, cut und sort, um die Namen der User alphabetisch zu sortieren.
 
* Kombiniere grep, cut und sort, um die Namen der User alphabetisch zu sortieren.
  <pre>grep "User" testfile.txt | cut -d' ' -f2 | sort</pre>
+
{| class="mw-collapsible mw-collapsed"
* Finde Telefonnummern, entferne Leerzeichen und speichere sie in einer neuen Datei.
+
! Lösung
  <pre>grep -E "[0-9]{3}-[0-9]{3}-[0-9]{4}" testfile.txt | tr -d ' ' > phones.txt</pre>
+
|-
* Zähle die Zeilen, die das Wort "Error" enthalten, und speichere die Anzahl in einer Datei.
+
| <pre>grep "User" testfile.txt | cut -d' ' -f2 | sort</pre>
  <pre>grep -c "Error" testfile.txt > error_count.txt</pre>
+
|}
  
 
----
 
----

Version vom 18. März 2025, 11:46 Uhr

🔍 grep – Suchen in der Datei

Übung:

  • Finde alle Zeilen, die das Wort "User" enthalten.
Lösung
grep "User" testfile.txt
  • Suche Zeilen, die mit "Error" beginnen.
Lösung
grep "^Error" testfile.txt
  • Finde alle Zeilen, die nicht "Success" enthalten.
Lösung
grep -v "Success" testfile.txt

🔢 wc – Zählen von Zeilen, Wörtern und Zeichen

Übung:

  • Zähle die Anzahl der Zeilen in der Datei.
Lösung
wc -l testfile.txt
  • Zähle die Wörter in der Datei.
Lösung
wc -w testfile.txt

🔤 tr – Zeichen umwandeln oder entfernen

Übung:

  • Ersetze alle Kleinbuchstaben durch Großbuchstaben.
Lösung
tr 'a-z' 'A-Z' < testfile.txt
  • Entferne alle Ziffern.
Lösung
tr -d '0-9' < testfile.txt

✂️ cut – Spalten aus der Datei extrahieren

Übung:

  • Extrahiere die erste Spalte aus Zeilen mit "User".
Lösung
grep "User" testfile.txt | cut -d' ' -f2
  • Schneide die ersten 10 Zeichen jeder Zeile ab.
Lösung
cut -c1-10 testfile.txt

📝 sed – Suchen und Ersetzen

Übung:

  • Ersetze "Alice" durch "Alicia".
Lösung
sed 's/Alice/Alicia/' testfile.txt
  • Lösche alle Zeilen, die mit # beginnen.
Lösung
sed '/^#/d' testfile.txt

🔀 sort – Sortieren der Datei

Übung:

  • Sortiere die Datei alphabetisch.
Lösung
sort testfile.txt
  • Sortiere rückwärts.
Lösung
sort -r testfile.txt

🔹 Shell-Sonderzeichen (*, ?, [ ])

Übung:

  • Zeige alle Dateien im aktuellen Verzeichnis, die mit "t" beginnen.
Lösung
ls t*
  • Zeige Dateien an, die genau vier Zeichen lang sind.
Lösung
ls ????

🔎 Reguläre Ausdrücke (grep -E)

Übung:

  • Finde Telefonnummern (Muster: 123-456-7890).
Lösung
grep -E "[0-9]{3}-[0-9]{3}-[0-9]{4}" testfile.txt

🔄 Mehrere Befehle nacheinander ausführen

Übung:

  • Kombiniere grep, cut und sort, um die Namen der User alphabetisch zu sortieren.
Lösung
grep "User" testfile.txt | cut -d' ' -f2 | sort

📄 Testdatei (testfile.txt)

Erstelle eine Datei `testfile.txt` mit folgendem Inhalt:

# Dies ist eine Testdatei für Linux-Befehle
User: Alice Age: 30 Location: Berlin
User: Bob Age: 25 Location: Hamburg
User: Charlie Age: 35 Location: Munich
Error: File not found
Warning: Low disk space
Success: Operation completed

123-456-7890
+49 176 1234567
abc_def_ghi
Hello, world!
The quick brown fox jumps over the lazy dog.

linux Linux LiNuX
apple banana apple cherry
zebra apple mango banana