Home >Backend Development >Golang >How to Iterate Over Strings by Runes in Go?
Iterating Over Strings By Runes in Go
Iterating over strings character by character can be useful in various programming scenarios. However, in Go, accessing characters directly using str[i] results in accessing bytes rather than Unicode runes. Therefore, it's necessary to explore alternative methods for iterating over strings by runes.
To iterate over a string by runes, you can utilize the range keyword. As demonstrated in the example from Effective Go:
for pos, char := range "日本語" { fmt.Printf("character %c starts at byte position %d\n", char, pos) }
This loop will iterate over the Unicode code points in the string, printing the character and its corresponding byte position.
The key takeaway is that the range keyword intelligently parses the UTF-8 string, breaking it down into individual Unicode code points, resulting in more efficient and convenient iteration.
The above is the detailed content of How to Iterate Over Strings by Runes in Go?. For more information, please follow other related articles on the PHP Chinese website!