Bash Hvordan utføre en kommando i en variabel?

Bash How Execute Command Variable



Bash -skript kan opprettes på en rekke forskjellige måter, og de fleste av oss er kjent med å utføre de enkle kommandoene i et Bash -script. Disse kommandoene kan imidlertid også være innkapslet i variablene i Bash. Denne prosessen er kjent som kommandosubstitusjon, og den brukes vanligvis til å lagre utdataene fra en kommando i en variabel, slik at du ikke trenger å kjøre kommandoen eksplisitt igjen og igjen, du kan ganske enkelt få tilgang til variabelen for å få utdata fra den kommandoen når som helst. I denne artikkelen vil vi vise deg hvordan dette kan gjøres.

Merk: Alle scenariene vist nedenfor er utført på Ubuntu 20.04. Imidlertid vil de fungere nøyaktig på samme måte med alle andre smaker av Linux også.







Metode for å utføre en kommando i en variabel i Bash:

For å demonstrere metoden for å utføre en kommando i en variabel i Bash, vil vi presentere for deg tre forskjellige scenarier som er som følger:



Utføre ekkokommandoen lagret i en variabel:

Dette er det enkleste scenariet der målet vårt er å utføre ekkokommandoen som er lagret i en variabel. For at det skal skje, må du følge trinnene som er nevnt nedenfor:



Trinn 1: Opprette et Bash -skript:

Du må opprette et Bash -skript i Hjem -mappen du trenger å klikke på Filbehandling -ikonet som du kan se fra følgende bilde:





Finn nå plass i Hjem-mappen og høyreklikk på den for å åpne en meny. Velg alternativet Nytt dokument fra denne menyen, og velg deretter Tøm dokument-alternativet fra undermålingsmenyen. Hvis du gjør dette, opprettes et nytt dokument i Hjem -mappen. Gi nå nytt navn til dette nyopprettede dokumentet med et hvilket som helst navn etter eget valg etterfulgt av .sh -utvidelsen. I vårt tilfelle har vi kalt det som CommandVar.sh.



For å skrive et Bash -skript i denne filen, dobbeltklikker du på det for å åpne det og skriver deretter inn skriptet som vises på bildet nedenfor i Bash -filen. Her viser den første linjen i skriptet, dvs. #!/Bin/bash at denne filen faktisk er en Bash -fil. Deretter har vi opprettet en variabel som heter test og har tildelt den verdien $ (ekko Hei!). Når du vil lagre kommandoen i en variabel, må du skrive inn kommandoen foran et $ -symbol. I dette tilfellet ønsket vi å lagre ekkokommandoen i testvariabelen, så vi har ganske enkelt skrevet inn ekkokommandoen etterfulgt av en tilfeldig melding og lagt den inn i parenteser og plassert et $ -symbol foran den. Så nå, hvis vi ønsker å utføre denne ekkokommandoen, må vi få tilgang til testvariabelen. Derfor, for å bekrefte om ekkokommandoen som er lagret i testvariabelen kan utføres vellykket eller ikke, har vi skrevet ut utgangen til testvariabelen på terminalen ved å bruke en annen ekkokommando. Etter at du har skrevet dette skriptet, må du lagre filen og lukke den.

Trinn 2: Utførelse av Bash -skriptet via terminalen:

Nå må du utføre dette skriptet via terminalen. Så, åpne terminalen i Ubuntu 20.04 og skriv inn følgende kommando i den:

bashCommandVar.sh

Når du trykker på Enter -tasten for å utføre denne kommandoen, vil du kunne se følgende utgang på terminalen. Her er den uthevede delen av utgangen utgangen fra ekkokommandoen som ble lagret i testvariabelen.

Utføre seq -kommandoen lagret i en variabel:

I dette scenariet vil vi skrive ut en sekvens med tall ved å bruke seq -kommandoen som er lagret i en variabel. For å få det til å skje, vil vi endre Bash -skriptet som ble opprettet ovenfor ved å utføre følgende trinn:

Trinn 1: Endre Bash Script Skapt ovenfor:

Åpne Bash -filen du har opprettet i metoden ovenfor, og skriv inn følgende skript i den. Her har vi opprettet en variabel som heter sekvens. Målet vårt er å skrive ut tallene fra 1 til 10 mens du bruker kommandoen seq. For å gjøre det har vi tilordnet verdien $ (seq 1 10) til sekvensvariabelen. Du kan også angi andre valgfrie numre du ønsker. Det første tallet etter kommandoen seq indikerer den nedre grensen for sekvensen, mens det andre tallet refererer til den øvre grensen. Etter at du har skrevet dette skriptet, lagrer du filen og lukker den.

Trinn 2: Utføre det modifiserte Bash -skriptet via terminalen:

Utfør nå Bash -skriptet på samme måte som forklart ovenfor, og du vil kunne se den angitte sekvensen på terminalen din som vist på bildet nedenfor:

Utføre 'pwd' kommando lagret i en variabel:

Du kan også skrive ut arbeidskatalogen din ved å bruke pwd -kommandoen som er lagret i en variabel. For å demonstrere dette, vil vi endre Bash -skriptet som ble opprettet ovenfor igjen ved å følge trinnene nevnt nedenfor:

Trinn 1: Endre Bash Script Skapt ovenfor:

Åpne Bash -filen du nettopp har endret, og skriv deretter inn skriptet som vises i bildet nedenfor. I dette skriptet har vi opprettet en variabel som heter working_directory og har tildelt verdien $ (pwd). Pwd -kommandoen vil ganske enkelt lagre utdataene, dvs. den nåværende arbeidskatalogen i variabelen working_directory. For å sikre om pwd -kommandoen er korrekt utført eller ikke, har vi skrevet ut verdien av variabelen working_directory på terminalen ved hjelp av ekkokommandoen. Lagre denne filen og lukk den etter at du har skrevet det modifiserte Bash -skriptet i den.

Trinn 2: Utføre det modifiserte Bash -skriptet via terminalen:

Utfør nå dette Bash -skriptet på samme måte som forklart ovenfor. Utdataene fra dette Bash -skriptet viser deg den nåværende arbeidskatalogen. Den uthevede delen av utgangen er faktisk utgangen fra pwd -kommandoen.

Konklusjon:

Denne artikkelen gir en veldig god ide om hvordan du kan utføre en kommando som er lagret i en variabel i Bash og kan få samme utgang som du ville ha fått hvis du kjørte kommandoen uavhengig.