209 lines
5.0 KiB
Go
209 lines
5.0 KiB
Go
|
// Package util ...
|
|||
|
//
|
|||
|
// Description : util ...
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 2023-06-25 17:22
|
|||
|
package util
|
|||
|
|
|||
|
import "github.com/mozillazg/go-pinyin"
|
|||
|
|
|||
|
// PinYinArg 设置选项方法
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:33 2023/6/25
|
|||
|
type PinYinArg func(arg *pinyin.Args)
|
|||
|
|
|||
|
// 拼音风格的设置
|
|||
|
|
|||
|
// PinYinStyleNormal ...
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:37 2023/6/25
|
|||
|
func PinYinStyleNormal() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Style = pinyin.Normal
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYinStyleToneStand 声调风格1,拼音声调在韵母第一个字母上。如: zhōng guó
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:38 2023/6/25
|
|||
|
func PinYinStyleToneStand() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Style = pinyin.Tone
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYinStyleToneAfterYunMu 声调风格2,即拼音声调在各个韵母之后,用数字 [1-4] 进行表示。如: zho1ng guo2
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:39 2023/6/25
|
|||
|
func PinYinStyleToneAfterYunMu() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Style = pinyin.Tone2
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYinStyleToneAtEnding 声调风格3,即拼音声调在各个拼音之后,用数字 [1-4] 进行表示。如: zhong1 guo2
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:40 2023/6/25
|
|||
|
func PinYinStyleToneAtEnding() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Style = pinyin.Tone3
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYinStyleShengMu 声母风格,只返回各个拼音的声母部分。如: zh g 。注意:不是所有的拼音都有声母
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:41 2023/6/25
|
|||
|
func PinYinStyleShengMu() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Style = pinyin.Initials
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYinStyleFirstLetter 首字母风格,只返回拼音的首字母部分。如: z g
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:42 2023/6/25
|
|||
|
func PinYinStyleFirstLetter() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Style = pinyin.FirstLetter
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYinStyleYunMu 韵母风格,只返回各个拼音的韵母部分,不带声调。如: ong uo
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:43 2023/6/25
|
|||
|
func PinYinStyleYunMu() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Style = pinyin.Finals
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYinStyleToneYunMu 韵母风格1,带声调,声调在韵母第一个字母上。如: ōng uó
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:44 2023/6/25
|
|||
|
func PinYinStyleToneYunMu() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Style = pinyin.FinalsTone
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYinStyleToneYunMuAtStart 韵母风格2,带声调,声调在各个韵母之后,用数字 [1-4] 进行表示。如: o1ng uo2
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:45 2023/6/25
|
|||
|
func PinYinStyleToneYunMuAtStart() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Style = pinyin.FinalsTone2
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYinStyleToneYunMuAtEnding 韵母风格3,带声调,声调在各个拼音之后,用数字 [1-4] 进行表示。如: ong1 uo2
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:40 2023/6/25
|
|||
|
func PinYinStyleToneYunMuAtEnding() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Style = pinyin.FinalsTone3
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// 拼音风格设置结束
|
|||
|
|
|||
|
// PinYinStyleWithSeparator 设置拼音的分隔符
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:59 2023/6/25
|
|||
|
func PinYinStyleWithSeparator(separator string) PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
if len(separator) == 0 {
|
|||
|
return
|
|||
|
}
|
|||
|
arg.Separator = separator
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYinStyleWithHeteronym 开启多音字模式
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 18:03 2023/6/25
|
|||
|
func PinYinStyleWithHeteronym() PinYinArg {
|
|||
|
return func(arg *pinyin.Args) {
|
|||
|
arg.Heteronym = true
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
// PinYin 汉字转拼音
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:23 2023/6/25
|
|||
|
type PinYin struct {
|
|||
|
}
|
|||
|
|
|||
|
// Convert 汉字生成拼音
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 17:26 2023/6/25
|
|||
|
func (py *PinYin) Convert(text string, argFuncList ...PinYinArg) string {
|
|||
|
arg := pinyin.NewArgs()
|
|||
|
arg.Separator = " "
|
|||
|
for _, argFunc := range argFuncList {
|
|||
|
argFunc(&arg)
|
|||
|
}
|
|||
|
|
|||
|
return pinyin.Slug(text, arg)
|
|||
|
}
|
|||
|
|
|||
|
// ConvertSingle 每个字一个读音, 支持多音字
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 18:02 2023/6/25
|
|||
|
func (py *PinYin) ConvertSingle(text string, argFuncList ...PinYinArg) []string {
|
|||
|
arg := pinyin.NewArgs()
|
|||
|
arg.Separator = " "
|
|||
|
for _, argFunc := range argFuncList {
|
|||
|
argFunc(&arg)
|
|||
|
}
|
|||
|
|
|||
|
return pinyin.LazyPinyin(text, arg)
|
|||
|
}
|
|||
|
|
|||
|
// ConvertWithHeteronym 多音字模式
|
|||
|
//
|
|||
|
// Author : go_developer@163.com<白茶清欢>
|
|||
|
//
|
|||
|
// Date : 18:02 2023/6/25
|
|||
|
func (py *PinYin) ConvertWithHeteronym(text string, argFuncList ...PinYinArg) [][]string {
|
|||
|
arg := pinyin.NewArgs()
|
|||
|
arg.Separator = " "
|
|||
|
for _, argFunc := range argFuncList {
|
|||
|
argFunc(&arg)
|
|||
|
}
|
|||
|
return pinyin.Pinyin(text, arg)
|
|||
|
}
|