目錄
問題內容
解決方法
首頁 後端開發 Golang 如何將映射切片轉換為具有不同屬性的結構切片

如何將映射切片轉換為具有不同屬性的結構切片

Feb 08, 2024 pm 10:27 PM
鍵值對 overflow

如何將映射切片轉換為具有不同屬性的結構切片

php小編西瓜為您介紹如何將映射切片轉換為具有不同屬性的結構切片。在程式設計中,我們經常會遇到需要將一個映射切片轉換為具有不同屬性的結構切片的情況。這種轉換可以幫助我們更好地組織和管理資料。在本文中,我們將介紹一種簡單而有效的方法來實現此轉換,讓您的程式碼更有效率和靈活。讓我們一起來看看吧!

問題內容

我正在使用一個 api,我需要向它傳遞一個結構片段。 我有一片地圖,因此我需要將其轉換為一片結構。

package main

import "fmt"

func main() {
    a := []map[string]interface{}{}
    b := make(map[string]interface{})
    c := make(map[string]interface{})
    
    b["prop1"] = "foo"
    b["prop2"] = "bar"
    a = append(a, b)

    c["prop3"] = "baz"
    c["prop4"] = "foobar"
    a = append(a, c)

    fmt.println(a)
}
登入後複製
[map[prop1:foo prop2:bar] map[prop3:baz prop4:foobar]]
登入後複製

因此,在這個範例中,我有映射 a 的切片,其中包含 bc ,它們是具有不同鍵的字串的映射。

我希望將a 轉換為結構體切片,其中第一個元素是以prop1prop2 作為屬性的結構體,第二個元素是一個以prop3prop4 作為屬性的結構體。

這可能嗎?

我查看了 https://github.com/mitchellh/mapstruct 但我無法讓它適用於我的用例。我看過這個答案: https://stackoverflow.com/a/26746461/3390419

解釋如何使用該函式庫:

mapstructure.Decode(myData, &result)
登入後複製

然而,這似乎假設 result 是一個實例的結構是預先定義的,而在我的例子中,該結構是動態的。

解決方法

您可以做的是首先單獨循環每個映射,使用每個映射的鍵值對建立相應的 reflect.structfield 值切片。準備好這樣的切片後,您可以將其傳遞給reflect.structof,它將傳回一個表示動態結構類型的reflect.type 值,然後您可以將其傳遞給reflect.new 以建立一個reflect.value ,它將表示動態結構的實例(實際上是指向該結構的指標)。

例如

var result []any
for _, m := range a {
    fields := make([]reflect.StructField, 0, len(m))

    for k, v := range m {
        f := reflect.StructField{
            Name: k,
            Type: reflect.TypeOf(v), // allow for other types, not just strings
        }
        fields = append(fields, f)
    }

    st := reflect.StructOf(fields) // new struct type
    sv := reflect.New(st)          // new struct value

    for k, v := range m {
        sv.Elem(). // dereference struct pointer
                FieldByName(k).         // get the relevant field
                Set(reflect.ValueOf(v)) // set the value of the field
    }

    result = append(result, sv.Interface())
}
登入後複製

https://www.php.cn/link/3722e31eaa9efae6938cc5c435365dfd

#

以上是如何將映射切片轉換為具有不同屬性的結構切片的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Vue.js 字符串轉對象的的方法是什麼? Vue.js 字符串轉對象的的方法是什麼? Apr 07, 2025 pm 09:18 PM

使用 JSON.parse() 字符串轉對象最安全高效:確保字符串符合 JSON 規範,避免常見錯誤。使用 try...catch 處理異常,提升代碼健壯性。避免使用 eval() 方法,存在安全風險。對於巨大 JSON 字符串,可考慮分塊解析或異步解析以優化性能。

H5頁面製作是前端開發嗎 H5頁面製作是前端開發嗎 Apr 05, 2025 pm 11:42 PM

是的,H5頁面製作是前端開發的重要實現方式,涉及HTML、CSS和JavaScript等核心技術。開發者通過巧妙結合這些技術,例如使用<canvas>標籤繪製圖形或使用JavaScript控制交互行為,構建出動態且功能強大的H5頁面。

如何通過JavaScript或CSS控制瀏覽器打印設置中的頁首和頁尾? 如何通過JavaScript或CSS控制瀏覽器打印設置中的頁首和頁尾? Apr 05, 2025 pm 10:39 PM

如何使用JavaScript或CSS控制瀏覽器打印設置中的頁首和頁尾在瀏覽器的打印設置中,有一個選項可以控制是否顯�...

HadiDB:Python 中的輕量級、可水平擴展的數據庫 HadiDB:Python 中的輕量級、可水平擴展的數據庫 Apr 08, 2025 pm 06:12 PM

HadiDB:輕量級、高水平可擴展的Python數據庫HadiDB(hadidb)是一個用Python編寫的輕量級數據庫,具備高度水平的可擴展性。安裝HadiDB使用pip安裝:pipinstallhadidb用戶管理創建用戶:createuser()方法創建一個新用戶。 authentication()方法驗證用戶身份。 fromhadidb.operationimportuseruser_obj=user("admin","admin")user_obj.

Vue Axios請求的URL是否正確 Vue Axios請求的URL是否正確 Apr 07, 2025 pm 10:12 PM

是的,Vue Axios 請求的 URL 必須正確才能請求成功。 url 格式為:協議、主機名、資源路徑,可選查詢字符串。常見錯誤包括缺少協議、拼寫錯誤、重複斜杠、缺少端口號和查詢字符串格式不正確。驗證 URL 正確性的方法:在瀏覽器地址欄手動輸入、使用在線驗證工具或在請求中使用 Vue Axios 的 validateStatus 選項。

在移動端如何兼容多行溢出省略? 在移動端如何兼容多行溢出省略? Apr 05, 2025 pm 10:36 PM

移動端多行溢出省略在不同設備上的兼容問題在使用Vue2.0開發移動端應用時,常常會遇到需要對文本進行多行溢...

redis指令怎麼用 redis指令怎麼用 Apr 10, 2025 pm 08:45 PM

使用 Redis 指令需要以下步驟:打開 Redis 客戶端。輸入指令(動詞 鍵 值)。提供所需參數(因指令而異)。按 Enter 執行指令。 Redis 返迴響應,指示操作結果(通常為 OK 或 -ERR)。

Vue.js 中字符串轉對像用什麼方法? Vue.js 中字符串轉對像用什麼方法? Apr 07, 2025 pm 09:39 PM

Vue.js 中字符串轉對象時,首選 JSON.parse() 適用於標準 JSON 字符串。對於非標準 JSON 字符串,可根據格式採用正則表達式和 reduce 方法或解碼 URL 編碼字符串後再處理。根據字符串格式選擇合適的方法,並註意安全性與編碼問題,以避免 bug。

See all articles