קבוצות תווים
באש מספקת לנו מספר אופציות להשתמש בregex לשימושים שנצרכים לעיתים קרובות בלא לכתוב regex, היכולת הזאת בשפה של באש נקראת Character classes והיא נראית כך
אם נתבונן נראה שכל האותיות נמחקו אבל הרווחים נשארו, והסיבה לכך היא שהורדנו רק אותיות ולא את הרווחים, בשביל להסיר גם את הרווחים ניתן להשתמש בביטוי [:space:] שתופס רווחים.
להלן רשימה חלקית של הביטויים
#grep
#sed
#regex
#tr
Character classes
רמת קושי: #beginners
אני מניח שלכל אחד יש יחסי אהבה שנאה עם regex, regex מספק יכולת ממש טובה לבחור טקסט אבל הקריאות שלו מזעזעת במקרה הטוב.באש מספקת לנו מספר אופציות להשתמש בregex לשימושים שנצרכים לעיתים קרובות בלא לכתוב regex, היכולת הזאת בשפה של באש נקראת Character classes והיא נראית כך
[[:alpha:]]
, לדוגמה.$ echo "Have a nice day :-)" | tr -d "[[:alpha:]]"
:-)
ביטוי שבוחר את כל האותיות וכפי שניתן לראות כל האותיות נבחרו ונמחקו. אם נתבונן נראה שכל האותיות נמחקו אבל הרווחים נשארו, והסיבה לכך היא שהורדנו רק אותיות ולא את הרווחים, בשביל להסיר גם את הרווחים ניתן להשתמש בביטוי [:space:] שתופס רווחים.
$ echo "Have a nice day :-)" | tr -d "[[:alpha:][:space:]]"
:-)
במידה ונרצה להפוך את הביטוי ניתן לעשות זאת על ידי ^
$ echo "1 1 root root $" | tr -d "[^[:alpha:]]"
rootroot
בעבר מספיק היה להשתמש בסוגריים מרובעות פעם אחת בשביל לממש את הביטוי לדוגמה [:print:]
, בגרסאות החדשות יותר של gnu צריכים להכפיל את הסוגריים למימוש הביטוי, וכמובן ניתן להשתמש ביותר מביטוי אחד בתוך סוגריים כפי שראינו לעיל [[:alpha:][:space:]].להלן רשימה חלקית של הביטויים
[:alpha:] == אותיות
[:digit:] == מספרים
[:space:] == תוים לבנים
[:blank:] == רווחים וטאבים
[:punct:] == תווים מיוחדים
[:alnum:] == [:alpha:][:digit:]
[:graph:] == [:alnum:][:punct:]
[:print:] == [:alnum:][:punct:][:space:]
[:xdigit:] == Hex
#character_classes#grep
#sed
#regex
#tr
@bash_tips
Bash Tips
רצפים ופורמטים עם seq רמת קושי: #beginners כפי שאנו מכירים באש מאפשרת ליצור רצפים של מספרים על ידי שימוש ב Brace expansion (הביטוי שמתאר את הפעולה הבאה {10..1} ) וזה עובד יפה מאוד כשמשתמשים בזה עם מספרים cat myscript.sh for i in {1..10}; do echo $i…
איחוד רצפים seq
רמת קושי: #beginners
פקודת
תכונה שימושית נוספת שהפקודה מכילה היא האפשרות לקבוע איזה תו יפריד בין כל תו/מילה/מספר שהיא יוצרת
דוגמה שימושית בתכונה זו היא יצירת מחרוזת לregex שבוחרת שנים בין 2016 ל 2021 מבלי להיכנס לסינטקס הלא ברור של regex
#seq
#regex
@bash_tips
רמת קושי: #beginners
פקודת
seq
עליה דיברנו בעבר מאפשרת ליצור רצף של תוויםתכונה שימושית נוספת שהפקודה מכילה היא האפשרות לקבוע איזה תו יפריד בין כל תו/מילה/מספר שהיא יוצרת
דוגמה שימושית בתכונה זו היא יצירת מחרוזת לregex שבוחרת שנים בין 2016 ל 2021 מבלי להיכנס לסינטקס הלא ברור של regex
$ seq -s "|" 2016 2021
2016|2017|2018|2019|2020|2021
#seq
#regex
@bash_tips
לכתוב תנאים - הרחבה
רמת קושי: #beginners
מספר דרכים לכתוב תנאי בבאש, להלן קצת סדר
סוגריים עגולים כפולים (( ))
סוג תנאי שעובד רק על מספרים ומתאים לבדיקת פעולות חשבוניות.
פקודה הבודקת ביטויי השוואה ממש כמו if, מחזירה true ל0 וfalse לכל מה שאינו 0
פקודה המבצעת בדיוק את את אותן פעולת שמבצעת פקודת test, ההבדל היחידי בין השניים הוא שפקודת test תגיב לדגלי
חשוב לשים לב שמשתמשים ותיקים עלולים לתהות מה ההבדל בין
ובכן, בעוד הראשון הוא לעתים פקודה בפני עצמה (מקבילה ל־
$
למשל, במקום
אופרטור =~ מה חשוב לדעת?
חשוב רק לציין שבמידה ומשתמשים באופרטור ההשוואה
$
קרדיט: תודה רבה לתומר @tomer מקבוצת @linux_il על הפוסט! (אז מה אם הוא השתנה מעט)
למי שלא מכיר קבוצת לינוקס ישראל היא אחת הקבוצות היותר טובות והיותר פעילות בטלגרם (כל עוד לא מדברים על קאלי).
#[
#if
#test
#regex
#conditions
@bash_tips
רמת קושי: #beginners
מספר דרכים לכתוב תנאי בבאש, להלן קצת סדר
סוגריים עגולים כפולים (( ))
סוג תנאי שעובד רק על מספרים ומתאים לבדיקת פעולות חשבוניות.
if (( 1 == 1 )); thenפקודת test
...
פקודה הבודקת ביטויי השוואה ממש כמו if, מחזירה true ל0 וfalse לכל מה שאינו 0
test 1 -ne 0סוגרים מרובעים בודדים [ ]
test string1 = string2
test -n string
...
פקודה המבצעת בדיוק את את אותן פעולת שמבצעת פקודת test, ההבדל היחידי בין השניים הוא שפקודת test תגיב לדגלי
--help, ו --version
if [ 1 -ne 0 ]סוגריים מרובעים כפולים [[ ]]
if [ string1 = string2 ]
if [ -n string ]
חשוב לשים לב שמשתמשים ותיקים עלולים לתהות מה ההבדל בין
[
ל [[
. ובכן, בעוד הראשון הוא לעתים פקודה בפני עצמה (מקבילה ל־
test
) $
whereis [
[: /usr/bin/[ /usr/share/man/man1/[.1.gzהשנייה היא רק פקודה מובנית ב־shell ונותנת לנו יכולות מתקדמות יותר.
למשל, במקום
-eq
כדי לבחון שיוויון, אפשר להשתמש בסימן שיוויון נורמלי. if [[ 1 -eq 1 ]]
לעומתif [[ 1 = 1 ]]
וברמת העיקרון אפשר גם לוותר על תחימה במרכאות של מחרוזות שכוללות תו רווח כי ה־shell יצליח להבין איך להתמודד עם זה.if [ -f "$filename" ]
לעומתif [[ -f $filename ]]
כבונוס, ישנו את האופרטור החשוב =~ המאפשר להשתמש בביטויים רגולריים ישירות מתנאי ההשוואה, וכך לחסוך ביטויים לוגיים מורכבים.אופרטור =~ מה חשוב לדעת?
חשוב רק לציין שבמידה ומשתמשים באופרטור ההשוואה
=~
יש הבדל בין משתנה העטוף בגרשיים (להלן מגורגש) לכזה שאינו, ברגע שמעבירים לתנאי משתנה מגורגש הביטוי מחפש את כל מחרוזת הטקסט שבמשתנה בצורה גולמית ולא מנסה להשוות את המשתנה כביטוי regex$
cat file.txt
111+.*pdf{}[]$$
[[ $(cat file.txt) =~ "pdf{}" ]] && echo match
match$
[[ $(cat file.txt) =~ pdf{} ]] && echo match
$ echo $?
1מצד אחד זה מאפשר לנו לבדוק התאמה של תת מחרוזות שמכילות תווים מיוחדים בצורה גולמית, מצד שני מי שלא מכיר את צורת התנהגות זו עשוי לבזבז זמן ולתהות מדוע דברים אינם מתנהגים כמצופה.
קרדיט: תודה רבה לתומר @tomer מקבוצת @linux_il על הפוסט! (אז מה אם הוא השתנה מעט)
למי שלא מכיר קבוצת לינוקס ישראל היא אחת הקבוצות היותר טובות והיותר פעילות בטלגרם (כל עוד לא מדברים על קאלי).
#[
#if
#test
#regex
#conditions
@bash_tips
שימוש בsed עם extended regex
רמת קושי: #beginners
טיפ חביב וקצרצר בקשר ל sed, המבנה הבסיסי של הפקודה מתבסס על ביטוי regex ואז הוראה מה נרצה לבצע לכל דבר שתואם לביטוי, העניין הוא שsed ברירת מחדל אינו משתמש בתצורה המורחבת של regex.
בכדי לאפשר extended regex לsed ניתן להשתמש בדגל
#regex
#extended_regex
@bash_tips
רמת קושי: #beginners
טיפ חביב וקצרצר בקשר ל sed, המבנה הבסיסי של הפקודה מתבסס על ביטוי regex ואז הוראה מה נרצה לבצע לכל דבר שתואם לביטוי, העניין הוא שsed ברירת מחדל אינו משתמש בתצורה המורחבת של regex.
בכדי לאפשר extended regex לsed ניתן להשתמש בדגל
-E
או -r
$ sed -E 's/something_(aaa|bbb|ccc)//g#sed
#regex
#extended_regex
@bash_tips