增加yaml文件的序列化与反序列化
This commit is contained in:
41
json.go
41
json.go
@ -97,12 +97,24 @@ func (oj *ownJSON) UnmarshalWithNumberForStringIgnoreError(input string, receive
|
||||
// Author : go_developer@163.com<白茶清欢>
|
||||
//
|
||||
// Date : 21:56 2023/7/22
|
||||
func (oj *ownJSON) MarshalForByte(input any) []byte {
|
||||
func (oj *ownJSON) MarshalForByte(input any) ([]byte, error) {
|
||||
buffer := bytes.NewBuffer([]byte{})
|
||||
encoder := json.NewEncoder(buffer)
|
||||
encoder.SetEscapeHTML(false)
|
||||
_ = encoder.Encode(input)
|
||||
return buffer.Bytes()
|
||||
if err := encoder.Encode(input); nil != err {
|
||||
return nil, err
|
||||
}
|
||||
return buffer.Bytes(), nil
|
||||
}
|
||||
|
||||
// MarshalForByteIgnoreError 序列化并忽略异常
|
||||
//
|
||||
// Author : go_developer@163.com<白茶清欢>
|
||||
//
|
||||
// Date : 17:16 2024/10/23
|
||||
func (oj *ownJSON) MarshalForByteIgnoreError(input any) []byte {
|
||||
byteData, _ := oj.MarshalForByte(input)
|
||||
return byteData
|
||||
}
|
||||
|
||||
// MarshalForString 序列化并返回字符串
|
||||
@ -110,8 +122,21 @@ func (oj *ownJSON) MarshalForByte(input any) []byte {
|
||||
// Author : go_developer@163.com<白茶清欢>
|
||||
//
|
||||
// Date : 21:56 2023/7/22
|
||||
func (oj *ownJSON) MarshalForString(input any) string {
|
||||
return string(oj.MarshalForByte(input))
|
||||
func (oj *ownJSON) MarshalForString(input any) (string, error) {
|
||||
byteData, err := oj.MarshalForByte(input)
|
||||
if nil != err {
|
||||
return "", err
|
||||
}
|
||||
return string(byteData), nil
|
||||
}
|
||||
|
||||
// MarshalForStringIgnoreError ...
|
||||
//
|
||||
// Author : go_developer@163.com<白茶清欢>
|
||||
//
|
||||
// Date : 17:19 2024/10/23
|
||||
func (oj *ownJSON) MarshalForStringIgnoreError(input any) string {
|
||||
return string(oj.MarshalForByteIgnoreError(input))
|
||||
}
|
||||
|
||||
// Transition 数据结构转换 map/slice/struct => struct | struct => map/slice/struct
|
||||
@ -120,7 +145,7 @@ func (oj *ownJSON) MarshalForString(input any) string {
|
||||
//
|
||||
// Date : 18:25 2023/12/29
|
||||
func (oj *ownJSON) Transition(input any, receiver any) error {
|
||||
return oj.UnmarshalWithNumber(oj.MarshalForByte(input), receiver)
|
||||
return oj.UnmarshalWithNumber(oj.MarshalForByteIgnoreError(input), receiver)
|
||||
}
|
||||
|
||||
// TransitionIgnoreError ...
|
||||
@ -129,7 +154,7 @@ func (oj *ownJSON) Transition(input any, receiver any) error {
|
||||
//
|
||||
// Date : 16:57 2024/1/10
|
||||
func (oj *ownJSON) TransitionIgnoreError(input any, receiver any) {
|
||||
_ = oj.UnmarshalWithNumber(oj.MarshalForByte(input), receiver)
|
||||
_ = oj.UnmarshalWithNumber(oj.MarshalForByteIgnoreError(input), receiver)
|
||||
}
|
||||
|
||||
// MergeDataForMap 合并数据到map
|
||||
@ -205,7 +230,7 @@ func (oj *ownJSON) ConsoleOutput(data any) {
|
||||
case reflect.Struct:
|
||||
fallthrough
|
||||
case reflect.Ptr:
|
||||
_ = json.Indent(&out, []byte(oj.MarshalForString(data)+"\n"), "", "\t")
|
||||
_ = json.Indent(&out, []byte(oj.MarshalForStringIgnoreError(data)+"\n"), "", "\t")
|
||||
_, _ = out.WriteTo(os.Stdout)
|
||||
return
|
||||
case reflect.Int:
|
||||
|
Reference in New Issue
Block a user