成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在 Go 語言中使用 exec 包執(zhí)行 Shell 命令

開發(fā) 前端
我們可以運行任何我們希望的命令。就像我們使用 CMD、bash 或其他一些 shell 來運行命令一樣,它可以運行這些命令。

exec 是 os 包中的一個子包,它可用于使用 Go 運行外部命令。Go exec 命令教程展示了如何在 Golang 中執(zhí)行 shell 命令和程序。

要使用這個包,我們需要按如下方式導入:

import "os/exec"

1.使用 GoLang exec 包運行命令

我們可以運行任何我們希望的命令。就像我們使用 CMD、bash 或其他一些 shell 來運行命令一樣,它可以運行這些命令。

這是運行 ls? 命令的示例。新建一個 main.go :

package main

import (
"fmt"
"os/exec"
)

func main() {
cmd := exec.Command("ls")

e := cmd.Run()
CheckError(e)
}

func CheckError(e error) {
if e != nil {
fmt.Println(e)
}
}

Run? 函數(shù)啟動指定命令并等待它完成,而 Start 啟動指定命令但不等待它完成;我們需要使用Wait with Start。

然后新建一個 go.mod 文件:

$ go mod init main.go
go: creating new go.mod: module main.go
go: to add module requirements and sums:
go mod tidy

現(xiàn)在,程序將運行,但我們不會看到控制臺的任何輸出。原因是命令運行,輸出沒有發(fā)送到標準輸出。

$ go run main.go

所以,我們需要修復它。添加下面顯示的兩行以查看控制臺的任何輸出。

cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr

輸出將顯示當前目錄中的文件。

package main

import (
"fmt"
"os"
"os/exec"
)

func main() {
cmd := exec.Command("ls", "-lah")

cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr

e := cmd.Run()
CheckError(e)

}

func CheckError(e error) {
if e != nil {
fmt.Println(e)
}
}

然后我們再程序,可以看到標準臺輸出如下的文件:

$ go run main.go
total 16
drwxr-xr-x 4 yuzhou_1su staff 128B 5 15 22:56 .
drwxr-xr-x 23 yuzhou_1su staff 736B 5 15 22:53 ..
-rw-r--r-- 1 yuzhou_1su staff 24B 5 15 22:56 go.mod
-rw-r--r-- 1 yuzhou_1su staff 248B 5 15 23:18 main.go

利用直接 ls 直接運行該命令,可以看到結果正確:

$ ls -alh
total 16
drwxr-xr-x 4 yuzhou_1su staff 128B 5 15 22:56 .
drwxr-xr-x 23 yuzhou_1su staff 736B 5 15 22:53 ..
-rw-r--r-- 1 yuzhou_1su staff 24B 5 15 22:56 go.mod
-rw-r--r-- 1 yuzhou_1su staff 248B 5 15 23:18 main.go

2.為不同的操作系統(tǒng)指定命令

我們可以指定針對不同操作系統(tǒng)運行不同的命令(例如 Linux 上的 bash 命令)。這是一個例子。

if runtime.GOOS == "linux" {
cmd = exec.Command("ls")
}

為此,我們還需要導入運行時包。

要查看所有可能的操作系統(tǒng),我們可以運行 go tool dist list ,它將顯示所有可能的操作系統(tǒng)和 ARCH 組合。

3.Go exec 命令捕獲輸出

輸出運行命令并返回其標準輸出:

package main

import (
"fmt"
"log"
"os/exec"
)

func main() {

out, err := exec.Command("ls", "-l").Output()

if err != nil {
log.Fatal(err)
}

fmt.Println(string(out))
}

運行該程序:

$ go run main.go
total 16
-rw-r--r-- 1 yuzhou_1su staff 24 5 15 22:56 go.mod
-rw-r--r-- 1 yuzhou_1su staff 180 5 15 23:33 main.go

4.Go cmd.StdinPipe

管道允許我們將一個命令的輸出發(fā)送到另一個命令。 StdinPipe 返回一個管道,該管道將在命令啟動時連接到命令的標準輸入。

package main

import (
"fmt"
"io"
"log"
"os/exec"
)

func main() {

cmd := exec.Command("cat")
stdin, err := cmd.StdinPipe()
if err != nil {
log.Fatal(err)
}

go func() {
defer stdin.Close()
io.WriteString(stdin, "an old falcon")
}()

out, err := cmd.CombinedOutput()
if err != nil {
log.Fatal(err)
}

fmt.Printf("%s\n", out)
}

在代碼示例中,我們將字符串寫入 goroutine 內的標準輸入。

cmd := exec.Command("cat")

cat 命令將給定的文件連接到標準輸出。當沒有給定文件或帶有 - 時,該命令讀取標準輸入并將其打印到標準輸出。

stdin, err := cmd.StdinPipe()

我們得到 cat 命令的標準輸入管道。

go func() {
defer stdin.Close()
io.WriteString(stdin, "an old falcon")
}()

在 goroutine 內部,我們將一個字符串寫入標準輸入管道。

$ go run stdinpipe.go 
an old falcon

5.Go cmd.StdoutPipe

StdoutPipe 返回一個管道,該管道將在命令啟動時連接到命令的標準輸出。

package main

import (
"fmt"
"io/ioutil"
"log"
"os/exec"
"strings"
)

func upper(data string) string {

return strings.ToUpper(data)
}

func main() {
cmd := exec.Command("echo", "an old falcon")

stdout, err := cmd.StdoutPipe()

if err != nil {
log.Fatal(err)
}

if err := cmd.Start(); err != nil {
log.Fatal(err)
}

data, err := ioutil.ReadAll(stdout)

if err != nil {
log.Fatal(err)
}

if err := cmd.Wait(); err != nil {
log.Fatal(err)
}

fmt.Printf("%s\n", upper(string(data)))
}

該示例通過管道讀取 echo 命令的輸出并將其轉換為大寫字母。

cmd := exec.Command("echo", "an old falcon")

要運行的命令是帶有單個字符串參數(shù)的 echo 命令。

stdout, err := cmd.StdoutPipe()

我們得到標準輸出管道。

if err := cmd.Start(); err != nil {
log.Fatal(err)
}

該命令使用 Start 函數(shù)執(zhí)行;它不會等待它完成。

data, err := ioutil.ReadAll(stdout)

我們從管道中讀取數(shù)據(jù)。

if err := cmd.Wait(); err != nil {
log.Fatal(err)
}

Wait 等待命令退出并等待任何復制到 stdin 或從 stdout 或 stderr 復制完成。它在看到命令退出后關閉管道。

運行該程序:

$ go run stdoutpipe.go 
AN OLD FALCON

6.總結

os/exec? 包運行外部命令。它包裝了 os.StartProcess 以便更輕松地重新映射標準輸入和標準輸出、將 I/O 與管道連接以及進行其他調整。

參考鏈接:https://zetcode.com/golang/exec-command/

責任編輯:武曉燕 來源: 宇宙之一粟
相關推薦

2013-06-25 09:52:32

GoGo語言Go編程

2011-05-25 13:22:05

PHPJSON

2019-08-28 09:04:02

Go語言Python操作系統(tǒng)

2024-05-10 08:36:40

Go語言對象

2023-03-02 19:36:34

C語言

2014-04-09 09:32:24

Go并發(fā)

2016-02-22 15:02:57

GoRedis連接池

2022-09-29 10:01:05

Go編程語言文本文件

2023-12-25 09:58:25

sync包Go編程

2024-04-01 00:02:56

Go語言代碼

2017-04-05 13:17:26

LinuxShellvi

2023-11-27 19:39:46

Goprotobuf

2012-05-08 11:11:43

Linuxcrontab命令

2023-10-09 07:14:42

panicGo語言

2021-02-27 10:20:18

Go語言flag包開發(fā)技術

2009-11-18 13:46:11

PHP命令行

2018-11-05 13:50:44

Linux命令tcpdump

2023-11-27 17:03:45

syncGo

2010-03-04 15:28:01

Ubuntu Shel

2024-01-07 23:11:16

defer?Go語言
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久久久一区二区 | 日韩区| 日韩欧美三级电影在线观看 | 欧美日韩福利 | 精品视频国产 | 在线观看免费毛片 | 亚洲午夜精品 | 亚洲视频一区在线观看 | 日日夜夜草 | 成人性视频免费网站 | 久久一区二区三区四区五区 | 伊人精品在线视频 | www.4虎影院| 中文字幕日韩在线 | 午夜爽爽爽男女免费观看影院 | aaaaaaa片毛片免费观看 | 三级特黄特色视频 | 国产午夜高清 | 免费视频一区二区 | 国产精品资源在线 | 国产欧美日韩综合精品一 | 日本中文字幕在线观看 | 精品美女在线观看视频在线观看 | 二区在线视频 | 干狠狠 | 特一级毛片 | 91精品国产91久久久久久密臀 | 91麻豆精品国产91久久久久久久久 | 国产精品成人一区二区 | 一级在线 | 日韩精品久久久久久 | 亚洲国产aⅴ成人精品无吗 亚洲精品久久久一区二区三区 | 国产精品免费大片 | 久在线| 99久久久久久 | 亚洲欧美激情国产综合久久久 | 99re在线视频| 亚洲精品一区二区三区在线 | 日本久久久一区二区三区 | 成人在线不卡 | 婷婷综合五月天 |