map切片排序

PHP_LHF發表於2022-02-08

map切片根據某個欄位值進行排序

思路

  1. 以欄位值為 key 建立一個新的map mapData
  2. 以欄位值建立一個key的切片 keySplice
  3. 迴圈切片slice組裝新的mapDatakeySplice的切片
  4. keySplice 進行排序
  5. 迴圈 keySplicemapData中根據key取值
package main

import (
    "fmt"
    "sort"
    "strconv"
)

func main() {
    b := []map[string]string{}
    str1 := map[string]string{"name": "zhangsan", "age": "1"}
    str2 := map[string]string{"name": "zhangsan", "age": "111"}
    str3 := map[string]string{"name": "zhangsan", "age": "11"}
    str4 := map[string]string{"name": "zhangsan", "age": "2"}
    str5 := map[string]string{"name": "zhangsan", "age": "22"}
    str6 := map[string]string{"name": "zhangsan", "age": "222"}

    b = append(b, str1, str2, str3, str4, str5, str6)

    // 排序前
    fmt.Println(b)
    fmt.Printf("排序前 ==> %s \n", b)
    // 輸出結果 [map[age:1 name:zhangsan] map[age:111 name:zhangsan] map[age:11 name:zhangsan] map[age:2 name:zhangsan] map[age:22 name:zhangsan] map[age:222 name:zhangsan]]
    a, _ := fieldSort(b, "age")

    // 排序後
    fmt.Printf("排序後 ==> %s \n", a)
    // 輸出結果 [map[age:1 name:zhangsan] map[age:2 name:zhangsan] map[age:11 name:zhangsan] map[age:22 name:zhangsan] map[age:111 name:zhangsan] map[age:222 name:zhangsan]]
}

func fieldSort(slice []map[string]string, fieldName string) (data []map[string]string, err error) {
    mapData := make(map[int]map[string]string)
    var keySplice []int
    for _, v := range slice {
        // 字串轉int(根據型別進行轉換)
        key, err := strconv.Atoi(v[fieldName])
        if err != nil {
            return nil, err
        }
        mapData[key] = v
        keySplice = append(keySplice, key)
    }

    sort.Ints(keySplice)
    for _, v := range keySplice {
        data = append(data, mapData[v])
    }
    return data, err

}

也可以使用golang的內建方法 sort.Slice
方法 func Slice(x interface{}, less func(i int, j int) bool)

// sortType 為true時 升序 false 降序
func fieldSort(slice []map[string]string, fieldName string, sortType bool) (data []map[string]string) {
    sort.Slice(slice, func(i, j int) bool {
        numi, _ := strconv.Atoi(slice[i][fieldName])

        numj, _ := strconv.Atoi(slice[j][fieldName])

        if sortType {
            return numi < numj
        } else {
            return numi > numj
        }

    })
    return slice

}
本作品採用《CC 協議》,轉載必須註明作者和本文連結

相關文章