query_result.go
3.0 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
package k3cloud
import (
"encoding/json"
"strings"
"github.com/tidwall/gjson"
)
//QueryError 单据查询错误信息
type QueryError struct {
Result struct {
ResponseStatus struct {
ErrorCode int `json:"ErrorCode"`
IsSuccess bool `json:"IsSuccess"`
Errors []struct {
FieldName interface{} `json:"FieldName"`
Message string `json:"Message"`
DIndex int `json:"DIndex"`
} `json:"Errors"`
} `json:"ResponseStatus"`
} `json:"Result"`
}
func (qe QueryError) Error() string {
str := ""
for _, errMsg := range qe.Result.ResponseStatus.Errors {
str += errMsg.Message + ";"
}
return str
}
/*QueryResult 单据查询结果
当接口调用失败时得到的json 结构对应[][]QueryError,如:
[[{"Result":{"ResponseStatus":{"Errors":[{"Message":"元数据中标识为FUseOrg的字段不存在"}]}}}]]
当接口调用成功的得到的json结构对应[][]interface{},如:
[["xxx","abc",2345]]
*/
type QueryResult struct {
FieldKeys []string //对应的键名 ,注意数据的顺序
Buf []byte //原始的数据byte
}
func newQueryResult(buf []byte, keys string) *QueryResult {
return &QueryResult{
Buf: buf,
FieldKeys: strings.Split(keys, ","),
}
}
func (result *QueryResult) ToMapString() []map[string]string {
if result.IsError() {
return nil
}
jResult := gjson.ParseBytes(result.Buf)
mapResult := []map[string]string{}
var mapTemp map[string]string
for _, arr1 := range jResult.Array() {
mapTemp = make(map[string]string)
for index2, item := range arr1.Array() {
if index2 > len(result.FieldKeys) {
continue
}
keyName := result.FieldKeys[index2]
mapTemp[keyName] = item.String()
}
mapResult = append(mapResult, mapTemp)
}
return mapResult
}
func (result *QueryResult) ToMap() []map[string]interface{} {
if result.IsError() {
return nil
}
jResult := gjson.ParseBytes(result.Buf)
mapResult := []map[string]interface{}{}
var mapTemp map[string]interface{}
for _, arr1 := range jResult.Array() {
mapTemp = make(map[string]interface{})
for index2, item := range arr1.Array() {
if index2 > len(result.FieldKeys) {
continue
}
keyName := result.FieldKeys[index2]
mapTemp[keyName] = item.Value()
}
mapResult = append(mapResult, mapTemp)
}
return mapResult
}
func (result *QueryResult) Error() error {
var (
errMsg QueryError
err error
)
jResult := gjson.ParseBytes(result.Buf)
for _, arr1 := range jResult.Array() {
for _, item := range arr1.Array() {
if !item.IsObject() {
return nil
}
err = json.Unmarshal([]byte(item.Raw), &errMsg)
if err != nil {
return err
}
}
}
return errMsg
}
//TODO 将结果解析为结构体
// func (result *QueryResult) ToStruct(v interface{}) error {
// return nil
// }
func (result *QueryResult) IsError() bool {
jResult := gjson.ParseBytes(result.Buf)
for _, arr1 := range jResult.Array() {
for _, item := range arr1.Array() {
if item.IsObject() {
return true
}
}
}
return false
}