Windows下CMD執(zhí)行Go出現(xiàn)中文亂碼的解決方法
在cmd下運(yùn)行g(shù)o程序或者是GOLAND的Terminal下運(yùn)行g(shù)o程序會(huì)出現(xiàn)中文亂碼的情況。
go run ttypemain.go
???? Ping [127.0.0.1] ???? 32 ????????:
???? 127.0.0.1 ????: ???=32 ???<1ms TTL=128
???? 127.0.0.1 ????: ???=32 ???<1ms TTL=128
???? 127.0.0.1 ????: ???=32 ???<1ms TTL=128
???? 127.0.0.1 ????: ???=32 ???<1ms TTL=128127.0.0.1 ?? Ping ??????:
?????: ????? = 4??????? = 4????? = 0 (0% ???)??
?????г????????(????????λ):
因?yàn)镚o的編碼是 UTF-8,而CMD的活動(dòng)頁(yè)是cp936(GBK),因此產(chǎn)生亂碼。
在中文Windows系統(tǒng)中,如果一個(gè)文本文件是UTF-8編碼的,那么在CMD.exe命令行窗口(所謂的DOS窗口)中不能正確顯示文件中的內(nèi)容。在默認(rèn)情況下,命令行窗口中使用的代碼頁(yè)是中文或者美國(guó)的,即編碼是中文字符集或者英文字符集。
在CMD或者Terminal下運(yùn)行chcp查看活動(dòng)頁(yè)代碼:
chcp
活動(dòng)代碼頁(yè): 936
得到的結(jié)果是 中文 936,UTF-8的代碼頁(yè)為65001,可以直接使用 chcp 65001 將活動(dòng)代碼頁(yè) 改成65001,這樣UTF-8編碼的就顯示正常了。
chcp 65001
Active code page: 65001
go run ttypemain.go
Pinging [127.0.0.1] with 32 bytes of data:
Reply from 127.0.0.1: bytes=32 time<1ms TTL=128
Reply from 127.0.0.1: bytes=32 time<1ms TTL=128
Reply from 127.0.0.1: bytes=32 time<1ms TTL=128
Reply from 127.0.0.1: bytes=32 time<1ms TTL=128Ping statistics for 127.0.0.1:
Packets: Sent = 4, Received = 4, Lost = 0 (0% loss),
Approximate round trip times in milli-seconds:
Minimum = 0ms, Maximum = 0ms, Average = 0ms
或者將中文轉(zhuǎn)成UTF-8的編碼,完整代碼如下:
package main import ( ?? ?"bufio" ?? ?"fmt" ?? ?"golang.org/x/text/encoding/simplifiedchinese" ?? ?"os/exec" ) type Charset string const ( ?? ?UTF8 ? ?= Charset("UTF-8") ?? ?GB18030 = Charset("GB18030") ) func main() { ?? ?command := "ping" ?? ?params := []string{"127.0.0.1","-t"} ?? ?cmd := exec.Command(command, params...) ?? ?stdout, err := cmd.StdoutPipe() ?? ?if err != nil { ?? ??? ?fmt.Println(err) ?? ??? ?return ?? ?} ?? ?cmd.Start() ?? ?in := bufio.NewScanner(stdout) ?? ?for in.Scan() { ?? ??? ?cmdRe:=ConvertByte2String(in.Bytes(),"GB18030") ?? ??? ?fmt.Println(cmdRe) ?? ?} ?? ?cmd.Wait() } func ConvertByte2String(byte []byte, charset Charset) string { ?? ?var str string ?? ?switch charset { ?? ?case GB18030: ?? ??? ?var decodeBytes,_=simplifiedchinese.GB18030.NewDecoder().Bytes(byte) ?? ??? ?str= string(decodeBytes) ?? ?case UTF8: ?? ??? ?fallthrough ?? ?default: ?? ??? ?str = string(byte) ?? ?} ?? ?return str }
正在 Ping 127.0.0.1 具有 32 字節(jié)的數(shù)據(jù):
來(lái)自 127.0.0.1 的回復(fù): 字節(jié)=32 時(shí)間<1ms TTL=128
來(lái)自 127.0.0.1 的回復(fù): 字節(jié)=32 時(shí)間<1ms TTL=128
來(lái)自 127.0.0.1 的回復(fù): 字節(jié)=32 時(shí)間<1ms TTL=128
來(lái)自 127.0.0.1 的回復(fù): 字節(jié)=32 時(shí)間<1ms TTL=128
來(lái)自 127.0.0.1 的回復(fù): 字節(jié)=32 時(shí)間<1ms TTL=128
來(lái)自 127.0.0.1 的回復(fù): 字節(jié)=32 時(shí)間<1ms TTL=128
來(lái)自 127.0.0.1 的回復(fù): 字節(jié)=32 時(shí)間<1ms TTL=128
來(lái)自 127.0.0.1 的回復(fù): 字節(jié)=32 時(shí)間<1ms TTL=128
到此這篇關(guān)于Windows下CMD執(zhí)行Go出現(xiàn)中文亂碼的解決方法的文章就介紹到這了,更多相關(guān)CMD執(zhí)行Go中文亂碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Go語(yǔ)言使用Redis和Etcd實(shí)現(xiàn)高性能分布式鎖
這篇文章主要為大家介紹了Go語(yǔ)言使用Redis實(shí)現(xiàn)高性能分布式鎖示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12Go語(yǔ)言使用defer+recover解決panic導(dǎo)致程序崩潰的問(wèn)題
如果協(xié)程出現(xiàn)了panic,就會(huì)造成程序的崩潰,這時(shí)可以在goroutine中使用recover來(lái)捕獲panic,進(jìn)行處理,本文就詳細(xì)的介紹一下,感興趣的可以了解一下2021-09-09Golang語(yǔ)言實(shí)現(xiàn)gRPC的具體使用
本文主要介紹了Golang語(yǔ)言實(shí)現(xiàn)gRPC的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08golang 實(shí)現(xiàn)時(shí)間戳和時(shí)間的轉(zhuǎn)化
這篇文章主要介紹了golang 實(shí)現(xiàn)時(shí)間戳和時(shí)間的轉(zhuǎn)化操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-05-05GPT回答 go語(yǔ)言和C語(yǔ)言數(shù)組操作對(duì)比
這篇文章主要為大家介紹了GPT回答的go語(yǔ)言和C語(yǔ)言數(shù)組操作方法對(duì)比,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10golang?gorm框架數(shù)據(jù)庫(kù)的連接操作示例
這篇文章主要為大家介紹了golang?gorm框架數(shù)據(jù)庫(kù)操作示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2022-04-04Go語(yǔ)言學(xué)習(xí)之new函數(shù)的用法詳解
這篇文章主要為大家詳細(xì)介紹了Go語(yǔ)言中new()函數(shù)的相關(guān)知識(shí)以及具體用法,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解一下2023-05-05