-
Notifications
You must be signed in to change notification settings - Fork 0
/
47_json_bonus.go
89 lines (72 loc) · 2.76 KB
/
47_json_bonus.go
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
package main
import (
"encoding/json"
"fmt"
"os"
)
type response1 struct {
Page int
Fruits []string
}
type response2 struct {
Page int `json:"page"`
Fruits []string `json:"fruits"`
}
func main() {
// slicelar için json encoding örneği
mySlice := []string{"monday", "tuesday", "wednesday"}
mySliceEncoded, _ := json.Marshal(mySlice)
fmt.Println(string(mySliceEncoded))
// mapler için json encoding örneği
myMap := map[string]string{"book": "the sorrows of young werther", "author": "goethe"}
myMapEncoded, _ := json.Marshal(myMap)
fmt.Println(string(myMapEncoded))
/*
__aşağıdaki örnekler gobyexample.com/json dan alınmıştır__
*/
// encoding/json paketi özel veri tiplerinizi otomatik olarak encode eder (örneğin aşağıdaki response1 custom bir type bizim için)
// encode edilmiş çıktılara yalnızca export edilmiş alanları dahil eder (yani büyük harfle tanımlanmış)
// ve varsayılan olarak bu adları JSON anahtarları olarak kullanır
res1D := &response1{
Page: 1,
Fruits: []string{"apple", "peach", "pear"}}
// MarshalIndent ->> Daha okunabilir json çıktısı için!
res1B, _ := json.MarshalIndent(res1D, "", " ")
fmt.Println(string(res1B))
// struct alanlarında encode edilmiş verinin json keylerini etiketler (tag) ile
// customize edebiliyoruz. (bkz: __response2 struct__)
res2D := &response2{
Page: 1,
Fruits: []string{"apple", "peach", "pear"}}
res2B, _ := json.MarshalIndent(res2D, "", " ")
fmt.Println(string(res2B))
// aşağıda hangi veri tipinin geleceğini bilmediğimiz json tipini decode ediyoruz
byt := []byte(`{"num":6.13, "strs":["a", "b"]}`)
var dat map[string]interface{}
if err := json.Unmarshal(byt, &dat); err != nil {
panic(err)
}
// decoded mapteki değerleri kullanmak için önce uygun tip dönüşümlerini gerçekleştirmemiz gerekir
// num'ı float64'e dönüşütürülmesi gösterilmiştir
/*
TODO: Yeni go sürümlerinde araştır. dönüşüm gerçekleştirmeden veriye eriştim?
*/
num := dat["num"].(float64)
fmt.Println(num)
// iç içe geçmiş veriler (nested data) birçok dönüşüm gerektirir
strs := dat["strs"].([]interface{})
str1 := strs[0]
fmt.Println(str1)
// Ayrıca, JSON'ı custom veri tiplerine decode edebiliriz
// Decode edilmiş veriye erişirken type assertionlardan bizi kurtarır
str := `{"page": 1, "fruits": ["apple", "peach"]}`
res := response2{}
json.Unmarshal([]byte(str), &res)
fmt.Println(res)
fmt.Println(res.Fruits[0]) // fruits -> Fruits dönüşümünü yaptı!
// veri ve json gösterimleri arasında hep byte ve stringleri kullandık
// os.Stdout gibi os.writerları kullanarak da json encodingleri stream edebiliriz
enc := json.NewEncoder(os.Stdout)
d := map[string]int{"apple": 5, "lettuce": 7}
enc.Encode(d)
}