-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathstrings.go
104 lines (94 loc) · 2.2 KB
/
strings.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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
/*
字符串操作相关函数
*/
package Togo
import (
"bytes"
"errors"
"fmt"
"math"
"strings"
)
func Explode(str, sep string) ([]string, error) {
if sep == "" {
return []string{str}, nil
}
return strings.Split(str, sep), nil
}
func Htmlspecialchars_decode(s string) string {
s = strings.Replace(s, "<", "<", -1)
s = strings.Replace(s, ">", ">", -1)
s = strings.Replace(s, "&", "&", -1)
s = strings.Replace(s, `"`, `"`, -1)
s = strings.Replace(s, `'`, `'`, -1)
return s
}
func Htmlspecialchars(s string) string {
s = strings.Replace(s, "<", "<", -1)
s = strings.Replace(s, ">", ">", -1)
s = strings.Replace(s, "&", "&", -1)
s = strings.Replace(s, `"`, """, -1)
s = strings.Replace(s, `'`, "'", -1)
return s
}
func Trim(s1, s2 string) string {
return strings.Trim(s1, s2)
}
func Ltrim(s1, s2 string) string {
return strings.TrimLeft(s1, s2)
}
func Rtrim(s1, s2 string) string {
return strings.TrimRight(s1, s2)
}
func Strrev(s string) string {
if s == "" {
return s
}
defer func() {
if err := recover(); err != nil {
fmt.Println(err)
}
}()
length := len([]rune(s))
var re []rune = make([]rune, length)
i := 0
for _, v := range s {
re[length-i-1] = v
i++
}
return string(re)
}
func Chr(ascii int) (string, error) {
if ascii > 127 || ascii < 32 {
return "", errors.New("invalid ascii code.")
}
var buf bytes.Buffer
buf.Write([]byte{byte(ascii)})
return buf.String(), nil
}
/**
*使用此函数将字符串分割成小块非常有用。
*例如将 base64_encode() 的输出转换成符合 RFC 2045 语义的字符串。
*它会在每 chunklen 个字符后边插入 end。(按byte计数,不是rune!)
*/
func Chunk_split(body string, chunklen int, end string) (str string, err error) {
count := int(math.Ceil(float64(len(body) / chunklen)))
var buf bytes.Buffer
for i := 0; i < count-1; i++ { //防止访问越界
start := i * chunklen
_, err = buf.Write([]byte(body)[start : start+chunklen])
if err != nil {
break
}
_, err = buf.WriteString(end)
if err != nil {
break
}
}
_, err = buf.Write([]byte(body)[chunklen*(count-1):])
_, err = buf.WriteString(end)
if err != nil {
return "", err
}
return buf.String(), nil
}