語法:
os.Open()-->*File,err *****
File.Seek(offset, whence),設置光標的未知
offset,偏移量
whence,從哪開始:0從頭,1當前,2末尾
package main
import (
"os"
"fmt"
)
func main() {
/*
seek(offset int, whence int),表示設置光標的位置
offset int,設置多少個字節(jié)
whence int,從哪開始
0,距離文件開頭
1,當前的位置
2,距離文件末尾
*/
//file,_:= os.Open("C:\\liu\\pro\\aa.txt") //RDONLY
file,_:=os.OpenFile("C:\\liu\\pro\\aa.txt",os.O_RDWR,0)
//1.打開文件后,光標默認在文件開頭。
bs := make([] byte, 1)
defer file.Close()
//2.seek()
//設置光標的位置在:距離文件開頭,4個字節(jié)處。
//file.Seek(8,0)
count, _:= file.Read(bs)
fmt.Println(string(bs[:count])) //a
file.Seek(4,2)
//count, _= file.Read(bs)
//fmt.Println(string(bs[:count])) //
file.Write([]byte{65,66,67})
fmt.Println("寫完了。。")
}
補充:Go語言-命令行參數(os.Args, flag包)
大部分Go程序都是沒有UI的,運行在純命令行的模式下,該干什么全靠運行參數。
這里介紹下Go語言命令行程序和他們的參數。
1. os.Args
程序獲取運行他時給出的參數,可以通過os包來實現(xiàn)。先看代碼:
package main
import (
"fmt"
"os"
"strconv"
)
func main () {
for idx, args := range os.Args {
fmt.Println("參數" + strconv.Itoa(idx) + ":", args)
}
}
運行起來得到的如下:
$go run main.go 1 3 -X ?
參數0: /tmp/go-build116558042/command-line-arguments/_obj/exe/main
參數1: 1
參數2: 3
參數3: -X
參數4: ?
可以看到,命令行參數包括了程序路徑本身,以及通常意義上的參數。
程序中os.Args的類型是 []string ,也就是字符串切片。所以可以在for循環(huán)的range中遍歷,還可以用 len(os.Args) 來獲取其數量。
如果不想要輸出os.Args的第一個值,也就是可執(zhí)行文件本身的信息,可以修改上述程序:
for idx, args := range os.Args[1:] {
將range后面的切片,去掉第一個元素。
輸出切片的所有元素,還有更簡潔的方式:
fmt.Println(strings.Join(os.Args[1:], "\n"))
fmt.Println(os.Args[1:])
/*
后一種方式的結果是[1 3 -X ?],這是fmt.Println輸出切片的格式
*/
2. flag包
flag包相比單純的通過os.Args切片分析命令行參數,提供了更強的能力。
來看個例子:
package main
import (
"fmt"
"flag"
)
var b = flag.Bool("b", false, "bool類型參數")
var s = flag.String("s", "", "string類型參數")
func main() {
flag.Parse()
fmt.Println("-b:", *b)
fmt.Println("-s:", *s)
fmt.Println("其他參數:", flag.Args())
}
------------------------------------
$ go run main.go
-b: false
-s:
其他參數: []
------------------------------------
$ go run main.go -b
-b: true
-s:
其他參數: []
------------------------------------
$ go run main.go -b -s test others
-b: true
-s: test
其他參數: [others]
------------------------------------
$ go run main.go -help
Usage of /tmp/go-build080353851/command-line-arguments/_obj/exe/main:
-b bool類型參數
-s string
string類型參數
exit status 2
2.1 定義參數
使用flag包,首先定義待解析命令行參數,也就是以"-"開頭的參數,比如這里的 -b -s -help等。-help不需要特別指定,可以自動處理。
這里指定了兩個參數,-b和-s:
var b = flag.Bool("b", false, "bool類型參數")
var s = flag.String("s", "", "string類型參數")
-----------------
原型:
func Bool(name string, value bool, usage string) *bool
func String(name string, value string, usage string) *string
通過flag.Bool和flag.String,建立了2個指針b和s,分別指向bool類型和string類型的變量。所以后續(xù)要通過 *b 和 *s 使用變量值。
flag.Bool和flag.String的參數有3個,分別是命令行參數名稱,默認值,提示字符串。
參數 |
功能 |
name |
命令行參數名稱,比如 -b, -help |
value |
默認值,未顯式指定的參數,給出隱式的默認值,比如本例中-b未給出的話,*b=false |
usage |
提示信息,如果給出的參數不正確或者需要查看幫助 -help,那么會給出這里指定的字符串 |
2.2 解析參數
flag使用前,必須首先解析:
2.3 使用參數
上文已經說明,通過flag方法定義好的參數變量指針,通過間接引用操作即可使用其內容:
fmt.Println("-b:", *b)
fmt.Println("-s:", *s)
2.4 未解析參數
參數中沒有能夠按照預定義的參數解析的部分,通過flag.Args()即可獲取,是一個字符串切片。
fmt.Println("其他參數:", flag.Args())
需要注意的是,從第一個不能解析的參數開始,后面的所有參數都是無法解析的。即使后面的參數中含有預定義的參數:
$ go run main.go -b stop -s test others
-b: true
-s:
其他參數: [stop -s test others]
上面例子中,解析到stop,就已經無法繼續(xù)解析了,即使后面給出了預定義好的-s,也是不能獲取出來的。
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- go 實現(xiàn)簡易端口掃描的示例
- go xorm框架的使用
- 解析Go的Waitgroup和鎖的問題
- Go語言快速入門圖文教程
- Go語言獲取文件的名稱、前綴、后綴
- Go語言 如何實現(xiàn)RSA加密解密
- Go 自定義package包設置與導入操作
- 詳解Gotorch多機定時任務管理系統(tǒng)