为了账号安全,请及时绑定邮箱和手机立即绑定

在 GO 中打印表格的有效方法

在 GO 中打印表格的有效方法

Go
回首忆惘然 2021-12-27 10:50:52
好的,所以我想出了一个简单的方法来实现这一目标。我们首先使用calloc为数组分配内存:double* c_func(int n_rows) {    double* result;    result = calloc(n_rows, sizeof(double));    for (int i = 0; i < n_rows; ++i) {        result[i] = (double)i;    }    return result;}之后,我们只需在 Go 中将数据转换为正确的类型。诀窍是使用C.free释放从 C 端分配的内存。// convert C double pointer to float64 slice ...func doubleToFloats(in *C.double, size int) []float64 {    defer C.free(unsafe.Pointer(in))    out := (*[1 << 30]float64)(unsafe.Pointer(in))[:size:size]    return out}
查看完整描述

2 回答

?
MYYA

TA贡献1868条经验 获得超4个赞

tabwriter标准库中的包对于这种事情简单易行:


w := tabwriter.NewWriter(os.Stdout, 1, 1, 1, ' ', 0)

fmt.Fprintln(w, "a\tb\tc\td\t")

fmt.Fprintln(w, "aa\tbb\tcc\t")

fmt.Fprintln(w, "aaa\tbbb\tccc\t")

fmt.Fprintln(w, "aaaa\tbbbb\tcccc\tdddd\t")

w.Flush()


// Prints out:

// a    b    c    d 

// aa   bb   cc   

// aaa  bbb  ccc  

// aaaa bbbb cccc dddd 

您可以将 os.Stdout 替换为任何io.Writer.


查看完整回答
反对 回复 2021-12-27
?
慕丝7291255

TA贡献1859条经验 获得超6个赞

例如,


package main


import (

    "encoding/csv"

    "fmt"

    "os"

    "strconv"

)


func main() {

    outfile := "file.tsv"

    f, err := os.Create(outfile)

    if err != nil {

        fmt.Println(err)

        os.Exit(1)

    }

    defer f.Close()

    w := csv.NewWriter(f)

    defer w.Flush()

    w.Comma = '\t'


    a := []string{"a", "b"}

    i, j := 0, 1

    x := float64(2.7)


    // Write row.

    err = w.Write(

        []string{

            a[i], a[j],

            strconv.FormatFloat(x, 'f', 4, 64),

        },

    )

    if err != nil {

        fmt.Println(err)

    }

}

输出:


$ cat file.tsv

a   b   2.7000

$

如果您使用 goroutines,这里有一个使用互斥锁来保护 csv.Writer 的版本。


package main


import (

    "encoding/csv"

    "fmt"

    "os"

    "strconv"

    "sync"

)


type csvWriter struct {

    w *csv.Writer

    m sync.Mutex

}


func (c *csvWriter) write(rec []string) error {

    c.m.Lock()

    defer c.m.Unlock()

    return c.w.Write(rec)

}


func (c *csvWriter) flush() {

    c.m.Lock()

    defer c.m.Unlock()

    c.w.Flush()

}


func main() {

    outfile := "file.tsv"

    f, err := os.Create(outfile)

    if err != nil {

        fmt.Println(err)

        os.Exit(1)

    }

    defer f.Close()

    w := csvWriter{w: csv.NewWriter(f)}

    defer w.flush()

    w.w.Comma = '\t'


    a := []string{"a", "b"}

    i, j := 0, 1

    x := float64(2.7)


    // Write row.

    err = w.write(

        []string{

            a[i], a[j],

            strconv.FormatFloat(x, 'f', 4, 64),

        },

    )

    if err != nil {

        fmt.Println(err)

    }

}


查看完整回答
反对 回复 2021-12-27
  • 2 回答
  • 0 关注
  • 447 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信