go語言基礎 seek光標位置os包的使用

語法:

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,設置多少個字節
   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個字節處。
    //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包來實現。先看代碼:

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循環的range中遍歷,還可以用 len(os.Args) 來獲取其數量。

如果不想要輸出os.Args的第一個值,也就是可執行文件本身的信息,可以修改上述程序:

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類型的變量。所以後續要通過 *b 和 *s 使用變量值。

flag.Bool和flag.String的參數有3個,分別是命令行參數名稱,默認值,提示字符串。

參數 功能
name 命令行參數名稱,比如 -b, -help
value 默認值,未顯式指定的參數,給出隱式的默認值,比如本例中-b未給出的話,*b=false
usage 提示信息,如果給出的參數不正確或者需要查看幫助 -help,那麼會給出這裡指定的字符串

2.2 解析參數

flag使用前,必須首先解析:

flag.Parse()

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,就已經無法繼續解析瞭,即使後面給出瞭預定義好的-s,也是不能獲取出來的。

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。

推薦閱讀: