按照字母顺序对 csv 文件中的内容进行排序的 Go 代码示例
短信预约 -IT技能 免费直播动态提醒
珍惜时间,勤奋学习!今天给大家带来《按照字母顺序对 csv 文件中的内容进行排序的 Go 代码示例》,正文内容主要涉及到等等,如果你正在学习Golang,或者是对Golang有疑问,欢迎大家关注我!后面我会持续更新相关内容的,希望都能帮到正在学习的大家!
问题内容我正在尝试使用 go 根据第一列中的姓氏按字母顺序排序包含一系列名称的 .csv 文件。我到处寻找,但似乎找不到办法。有没有办法做到这一点,同时保持同一行中的其他值? 我有三个同名的 .csv 文件,但我必须对它们进行洗牌才能完成我的任务(随机表座位算法)。我希望能够将它们重新按定义的字母顺序排列,以便我可以确保人们不会连续坐在一起。
提前致谢。 :)
编辑:可能值得展示我用来洗牌的函数:
func Shuffle(slice []Person) []Person {
r := rand.New(rand.NewSource(time.Now().Unix()))
ret := make([]Person, len(slice))
n := len(slice)
for i := 0; i < n; i++ {
randIndex := r.Intn(len(slice))
ret[i] = slice[randIndex]
slice = append(slice[:randIndex], slice[randIndex+1:]...)
}
return ret
person[] 切片只是一个包含名字和姓氏的结构。
解决方案
go 的 sort
软件包附带了 great example。请参阅修改后的实现,它应该可以满足您的要求。
package main
import (
"encoding/csv"
"fmt"
"io"
"log"
"sort"
"strings"
)
// Unsorted sample data
var unsorted = `Balaam,Wileen,Saint Louis
Meachan,Lothaire,Lefengzhen
Scoggin,Ivonne,Pag
Hawarden,Audrye,Leiria
Claypool,Biddy,Maiorca
Stanford,Douglas,Báguanos
Petriello,Yvor,Obryte
Hatter,Margette,Luoping
Pepall,Linzy,Hucun
Carter,Kit,Parungjawa
`
type Person struct {
Lastname string
Firstname string
City string
}
// Create a new Person record from a given string slice
func NewPerson(fields []string) (p Person, err error) {
if len(fields) < 3 {
return p, fmt.Errorf("not enough data for Person")
}
p.Lastname = fields[0]
p.Firstname = fields[1]
p.City = fields[2]
return
}
// ByLastname implements sort.Interface for []Person based on the Lastname field.
type ByLastname []Person
func (a ByLastname) Len() int { return len(a) }
func (a ByLastname) Swap(i, j int) { a[i], a[j] = a[j], a[i] }
func (a ByLastname) Less(i, j int) bool { return a[i].Lastname < a[j].Lastname }
func main() {
// Open unsorted CSV from string
r := csv.NewReader(strings.NewReader(unsorted))
var people []Person
for {
// Read CSV line by line
record, err := r.Read()
if err == io.EOF {
break
}
if err != nil {
log.Fatal(err)
}
// Create Person from line in CSV
person, err := NewPerson(record)
if err != nil {
continue
}
people = append(people, person)
}
// Sort CSV by Lastname
sort.Sort(ByLastname(people))
// Print to stdout
for _, p := range people {
fmt.Printf("%s %s from %s\n", p.Lastname, p.Firstname, p.City)
}
// Here you would write your CSV
}
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持编程网!更多关于Golang的相关知识,也可关注编程网公众号。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341