sjson #1

Merged
zhangdeman merged 7 commits from sjson into master 2023-02-06 11:44:09 +08:00
Showing only changes of commit 123c22e8b2 - Show all commits

View File

@ -97,6 +97,10 @@ func (f *filter) IsArray(rule MapRule) bool {
// //
// Date : 17:41 2023/1/1 // Date : 17:41 2023/1/1
func (f *filter) handleArray(rule MapRule) error { func (f *filter) handleArray(rule MapRule) error {
var (
err error
)
sourcePathArray := strings.Split(rule.SourcePath, "[]") sourcePathArray := strings.Split(rule.SourcePath, "[]")
mapPathArray := strings.Split(rule.MapPath, "[]") mapPathArray := strings.Split(rule.MapPath, "[]")
if len(sourcePathArray) != len(mapPathArray) { if len(sourcePathArray) != len(mapPathArray) {
@ -104,21 +108,32 @@ func (f *filter) handleArray(rule MapRule) error {
return errors.New("map rule is invalid") return errors.New("map rule is invalid")
} }
// 提取某一个list下的字段, 组成一个list // 提取某一个list下的字段, 组成一个list
res := make([]string, 0)
f.getAllFinalData(res, gjson.Get(f.sourceData, sourcePathArray[0]).Array(), sourcePathArray[1:])
if f.formatResult, err = sjson.Set(f.formatResult, mapPathArray[0], res); nil != err {
return err
}
return nil return nil
} }
return nil return nil
} }
// getAllFinalData ... // extraFinalResult 提取全部最底层结果
// //
// Author : go_developer@163.com<白茶清欢> // Author : zhangdeman001@ke.com<张德满>
// //
// Date : 18:42 2023/1/1 // Date : 14:00 2023/1/2
func (f *filter) getAllFinalData(pathArr []string) []string { func (f *filter) getAllFinalData(res []string, resultList []gjson.Result, pathArr []string) {
res := make([]string, 0) if len(pathArr) == 0 {
for _, item := range resultList {
return res res = append(res, item.String())
}
return
}
for _, item := range resultList {
f.extraFinalResult(res, item.Array(), pathArr[1:])
}
return
} }
// String 获取格式化之后的字符串 // String 获取格式化之后的字符串