3 回答
TA贡献1895条经验 获得超7个赞
戈朗语中的 Unicode 字符(如中文字符)需要 3 个字节,而 ASCII 只需要 1 个字节。这是设计使然。
如果要检查 unicode 字符的实际字符串大小,请使用 unicode/utf8 内置包。
fmt.Printf("String: %s\nLength: %d\nRune Length: %d\n", c, len(c), utf8.RuneCountInString(c))
// String: 这是一个测试
// Length: 18
// Rune Length: 6
更基本的计数方法是使用 for 循环。
count := 0
for range "这是一个测试" {
count++
}
fmt.Printf("Count=%d\n", count)
// Count=6
关于表格格式的中英文字符串的漂亮印刷,似乎没有直接的方法。在这种情况下,制表符也不起作用。一个小的黑客解决这个问题是使用csv编写器,如下所示:
data := [][]string{
{"这是一个测试", "|"},
{"aaaaaaaaaa", "|"},
{"つのだ☆HIRO", "|"},
{"aaaaaaaaaa", "|"},
}
w := csv.NewWriter(os.Stdout)
defer w.Flush()
w.Comma = '\t'
for _, row := range data {
w.Write(row)
}
这应该按预期打印数据。不幸的是,堆栈溢出打印的格式与我在终端中看到的格式不同。但游乐场拯救了我们。点击这里
Note:这适用于符文大小彼此足够接近的字符串。对于更长的字符串,您需要更多的解决方法。
TA贡献1802条经验 获得超4个赞
我认为这是你想要的
func TestChinese(t *testing.T) {
tests := []string{
"这是一个测试",
"aaaaaaaaa",
"つのだ☆HIRO",
"aaaaaaaaaa",
"这是aaaaa一个测试",
"这是一个つの测试",
}
for _, tt := range tests {
fmt.Printf("%s\t%d\t%d\n", tt, len([]rune(tt)), len([]byte(tt)))
}
}
输出:
这是一个测试 6 18
aaaaaaaaa 9 9
つのだ☆HIRO 8 16
aaaaaaaaaa 10 10
这是aaaaa一个测试 11 23
这是一个つの测试 8 24
TA贡献1777条经验 获得超10个赞
您的问题(如mkopriva在评论中指出的那样)是一个显示问题,不适合通过任何类型的计数技巧来解决。
当我们用英语显示可变音高或比例文本与等宽文本时,我们遇到了同样的问题。也就是说,比较:
mmmm, tasty iiii, tasty?
跟:
嗯,好吃
,好吃吗?
(假设您使用浏览器阅读此答案!我们不必打印汉字,甚至不必留下简单的ASCII来解决问题!
您需要的是用于中文文本的等宽显示字体,或者可能是一些以表格形式排版的软件,以及您如何获得...完全是另一个问题。
- 3 回答
- 0 关注
- 158 浏览
添加回答
举报
