3 回答
TA贡献1873条经验 获得超9个赞
让我们忽略一个事实,那就是走一秒钟。您需要做的第一件事是将序列化格式编组为in []string。
这里有很多选择。您可以构建自己的库或使用库。我将假设您不想构建自己的格式,而是跳到支持序列化的格式。
在所有示例中,data是[]string您正在读取/写入的文件,而fp是您正在读取/写入的文件。错误被忽略,请检查函数的返回值以处理错误。
地精
Gob是只能执行的二进制格式。随着字符串数量的增加,它应该相对节省空间。
enc := gob.NewEncoder(fp)
enc.Encode(data)
阅读也很简单
var data []string
dec := gob.NewDecoder(fp)
dec.Decode(&data)
采空区很简单而且很关键。但是,该格式仅可与其他Go代码一起读取。
杰森
接下来是json。Json是一种几乎在所有地方都使用的格式。这种格式也很容易使用。
enc := json.NewEncoder(fp)
enc.Encode(data)
并阅读:
var data []string
dec := json.NewDecoder(fp)
dec.Decode(&data)
XML格式
XML是另一种常见格式。但是,它具有相当高的开销,并且不那么容易使用。尽管您可以像对gob和json一样进行操作,但正确的xml需要一个根标签。在这种情况下,我们使用根标签“ Strings”,每个字符串都包装在“ S”标签中。
type Strings struct {
S []string
}
enc := xml.NewEncoder(fp)
enc.Encode(Strings{data})
var x Strings
dec := xml.NewDecoder(fp)
dec.Decode(&x)
data := x.S
CSV
CSV与其他CSV不同。您有两个选择,使用一个记录包含n行或n个记录包含1行。下面的示例使用n条记录。如果我使用一张唱片,那会很无聊。看起来太像其他人了。CSV只能容纳字符串。
enc := csv.NewWriter(fp)
for _, v := range data {
enc.Write([]string{v})
}
enc.Flush()
阅读:
var err error
var data string
dec := csv.NewReader(fp)
for err == nil { // reading ends when an error is reached (perhaps io.EOF)
var s []string
s, err = dec.Read()
if len(s) > 0 {
data = append(data, s[0])
}
}
您使用哪种格式是优先选择的问题。我还没有提到许多其他可能的编码。例如,有一个名为bencode的外部库。我个人不喜欢bencode,但是它可以工作。它与bittorrent元数据文件使用的编码相同。
如果您要进行自己的编码,那么编码/二进制是一个不错的起点。这样可以使最紧凑的文件成为可能,但我认为值得付出努力几乎没有。
- 3 回答
- 0 关注
- 212 浏览
添加回答
举报