Betrachten wir zum Beispiel s := "世a界世bcd界efg世"
: 12 Runen. (Siehe play.golang.org)
Wenn Sie versuchen, es für Byte Byte zu analysieren, werden Sie (in einer naiven geteilte Implementierung alle 3 Zeichen) verpassen einige der "Index modulo 3" (entspricht 2, 5, 8 und 11), weil der Index Vergangenheit diese Werte erhöhen:
for i, r := range s {
res = res + string(r)
fmt.Printf("i %d r %c\n", i, r)
if i > 0 && (i+1)%3 == 0 {
fmt.Printf("=>(%d) '%v'\n", i, res)
res = ""
}
}
der Ausgang:
i 0 r 世
i 3 r a <== miss i==2
i 4 r 界
i 7 r 世 <== miss i==5
i 10 r b <== miss i==8
i 11 r c ===============> would print '世a界世bc', not exactly '3 chars'!
i 12 r d
i 13 r 界
i 16 r e <== miss i==14
i 17 r f ===============> would print 'd界ef'
i 18 r g
i 19 r 世 <== miss the rest of the string
Aber wenn man auf Runen (a := []rune(s)
) iterieren, würden Sie bekommen, was Sie erwarten, wie die Index würde inc Rease eine Rune zu einer Zeit, ist es leicht zu aggregieren genau 3 Zeichen machen:
for i, r := range a {
res = res + string(r)
fmt.Printf("i%d r %c\n", i, r)
if i > 0 && (i+1)%3 == 0 {
fmt.Printf("=>(%d) '%v'\n", i, res)
res = ""
}
}
Ausgang:
i 0 r 世
i 1 r a
i 2 r 界 ===============> would print '世a界'
i 3 r 世
i 4 r b
i 5 r c ===============> would print '世bc'
i 6 r d
i 7 r 界
i 8 r e ===============> would print 'd界e'
i 9 r f
i10 r g
i11 r 世 ===============> would print 'fg世'
Nun, einige Programmierung könnte hier helfen? Wie 's [n: n + 3] +" \ n "'? – Volker