size
dstgo/size ist eine sehr praktische Bibliothek zur gegenseitigen Konvertierung zwischen Strings und Dateigrößen.
Repository: dstgo/size: Fast conversion between file size and string (github.com)
Dokumentation: dstgo/size: Fast conversion between file size and string (github.com)
Installation
$ go get https://github.com/dstgo/sizeVerwendung
const (
B Size = 1
KB = B * 1024
MB = KB * 1024
GB = MB * 1024
TB = GB * 1024
PB = TB * 1024
)type SizeMeta struct {
Data float64
Unit Size
}Die Verwendung dieser Bibliothek ist sehr einfach, es gibt nur zwei öffentlich verfügbare Funktionen:
func ParseSize(str string) SizeMetaParseSize konvertiert einen String in eine SizeMeta-Struktur, die die Datengröße und die Größeneinheit speichert.
func ParseTargetSize(str string, size Size) SizeMetaParseTargetSize konvertiert einen String in eine SizeMeta mit der angegebenen Größe.
Beispiel:
package main
import (
"fmt"
"github.com/dstgo/size"
)
func main() {
parseSize := size.ParseSize("1.2MB")
fmt.Printf("%+v\n", parseSize)
fmt.Printf("%+v\n", parseSize.Round(1))
parseSize1 := size.ParseSize("2.3-asdajl")
fmt.Printf("%+v\n", parseSize1)
targetSize := size.ParseTargetSize("2.65MB", size.KB)
fmt.Printf("%+v", targetSize)
fmt.Printf("%+v", targetSize.String())
}Nach der Konvertierung kann die Round-Methode verwendet werden, um die Anzahl der Dezimalstellen festzulegen, oder die String-Methode, um die String-Darstellung zu erhalten. Beispielausgabe:
1.20MB
1.2
2713.60KB