登录
首页 >  Golang >  Go问答

文件解析基于字节部分

来源:stackoverflow

时间:2024-02-06 18:36:21 114浏览 收藏

“纵有疾风来,人生不言弃”,这句话送给正在学习Golang的朋友们,也希望在阅读本文《文件解析基于字节部分》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新Golang相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

问题内容

我正在解析一个文件,该文件是逐字节读取的,并且我有关于哪个字节代表文件的哪一部分的说明。

订单文件:

  1. 前 4 个字节是版本

  2. 接下来的 4 个字节是一个整数,表示预期的订单数量。

  3. 对于每个订单(从 #2 开始),4 字节整数是订单 id。

为了解析这个,我首先加载文件:

file, err := os.Open("orders.abc")

version := make([]byte, 4)
c, err := file.Read(version)
fmt.Printf("read %d, version is %d", c, version)

orderCount := make([]byte, 4)
c2, err := file.Read(orderCount)
fmt.Printf("read %d, orderCount is %d", c2, orderCount)

for i := 0; i < orderCount_as_int; i++ {

  orderId := make([]byte, 4)
  c3, err := file.Read(orderId)     
}

是否有更优雅的方式来解析这样的文件?

另外,如何将 version/ordercount 转换为整数以便我可以使用该值?


正确答案


您想要使用 encoding/binary.read 而不是直接调用 read。例如

var version int32
err := binary.Read(file, binary.LittleEndian, &version)

(您还需要知道文件中的数据是大端还是小端,并选择适当的字节顺序)。二进制包将为您进行解码。

本篇关于《文件解析基于字节部分》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>