1 Star 3 Fork 1

古丞秋/uymas

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
element.go 4.46 KB
一键复制 编辑 原始数据 按行查看 历史
package pinyin
import (
"gitee.com/conero/uymas/str"
"gitee.com/conero/uymas/util/rock"
"strings"
)
const (
SepTitle = `__LIB_TITLE__`
)
const (
_ = iota
// PinyinTone pinyin as tone for raw
PinyinTone
// PinyinNumber pinyin as tone for number
PinyinNumber
// PinyinAlpha pinyin as tone for alpha
PinyinAlpha
)
// Element the data dictionary enter
type Element struct {
Unicode string
// possible existence of polyphonic characters
pinyin string
// it can be chinese or other char
Text string
}
// IsEmpty test if is empty that support all unicode
func (e Element) IsEmpty() bool {
return e.pinyin == ""
}
// FirstPinyin if pinyin exists get the first pinyin, compatible with polyphonics
func (e Element) FirstPinyin() string {
list := e.PinyinList()
if list == nil {
return ""
}
return list[0]
}
// Polyphony test if the pinyin is polyphonic
func (e Element) Polyphony() bool {
return len(e.PinyinList()) > 1
}
// PinyinList get the polyphonic pinyin as list
func (e Element) PinyinList() []string {
if e.pinyin == "" {
return nil
}
return strings.Split(e.pinyin, ",")
}
// List the list of elements
type List []Element
func (e List) String() string {
var queue []string
for _, v := range e {
queue = append(queue, v.Text)
}
return strings.Join(queue, "")
}
// Tone Tone(seps, fmt string)
func (e List) Tone(seps ...string) string {
sep := rock.ExtractParam("", seps...)
vFmt := rock.ExtractParamIndex("", 2, seps...)
var queue []string
for _, v := range e {
if v.IsEmpty() {
queue = append(queue, v.Text)
} else {
queue = append(queue, PyinFormat(v.FirstPinyin(), vFmt))
}
}
return strings.Join(queue, sep)
}
// Number Number(seps, fmt string)
func (e List) Number(seps ...string) string {
sep := rock.ExtractParam("", seps...)
vFmt := rock.ExtractParamIndex("", 2, seps...)
var queue []string
for _, v := range e {
if v.IsEmpty() {
queue = append(queue, v.Text)
} else {
queue = append(queue, PyinFormat(PyinNumber(v.FirstPinyin()), vFmt))
}
}
return strings.Join(queue, sep)
}
// Alpha Alpha(seps, fmt string)
func (e List) Alpha(seps ...string) string {
sep := rock.ExtractParam("", seps...)
vFmt := rock.ExtractParamIndex("", 2, seps...)
var queue []string
for _, v := range e {
if v.IsEmpty() {
queue = append(queue, v.Text)
} else {
queue = append(queue, PyinFormat(PyinAlpha(v.FirstPinyin()), vFmt))
}
}
return strings.Join(queue, sep)
}
// Text get pinyin text as the list of element
func (e List) Text() []string {
var text []string
for _, v := range e {
text = append(text, v.Text)
}
return text
}
// Polyphony gets all columns composed of polyphonics
//
// Polyphony(vType int32, join string)
func (e List) Polyphony(vType int32, args ...string) []string {
joinSeq := rock.ExtractParam("", args...)
var polys []string
queue := polyphonyTraverse(e, 0, nil)
for _, qs := range queue {
var elStr string
switch vType {
case PinyinNumber:
elStr = strings.Join(PyinNumberList(qs), joinSeq)
case PinyinAlpha:
elStr = strings.Join(qs, joinSeq)
elStr = PyinAlpha(elStr, true)
default:
elStr = strings.Join(qs, joinSeq)
}
polys = append(polys, elStr)
}
return polys
}
// PyinFormat set format date
//
// support `title` like 'latest name' to 'Latest Name'
func PyinFormat(pinyin, vFmt string) string {
switch vFmt {
case SepTitle:
pinyin = str.Ucfirst(pinyin)
}
return pinyin
}
// recursive polyphonics
func polyphonyTraverse(ls List, next int, queue []string) [][]string {
vLen := len(ls)
var polyphonyLs [][]string
var tmpChildBranch [][]string
todoAppendFn := func(single string) {
if len(tmpChildBranch) > 0 {
for i, cld := range tmpChildBranch {
tmpChildBranch[i] = append(cld, single)
}
return
}
queue = append(queue, single)
}
for j := next; j < vLen; j++ {
elNext := ls[j]
if elNext.IsEmpty() {
queue = append(queue, elNext.Text)
continue
}
l := elNext.PinyinList()
if len(l) == 1 {
todoAppendFn(elNext.pinyin)
continue
}
var tcbNext [][]string
for _, cv := range l {
if len(tmpChildBranch) > 0 {
for _, tcb := range tmpChildBranch {
tcbNext2 := polyphonyTraverse(ls, j+1, append(tcb, cv))
tcbNext = append(tcbNext, tcbNext2...)
}
continue
}
for _, cn := range polyphonyTraverse(ls, j+1, append(queue, cv)) {
tcbNext = append(tcbNext, cn)
}
}
tmpChildBranch = tcbNext
break
}
if len(tmpChildBranch) > 0 {
return tmpChildBranch
}
polyphonyLs = append(polyphonyLs, queue)
return polyphonyLs
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/conero/uymas.git
git@gitee.com:conero/uymas.git
conero
uymas
uymas
v1.4.2

搜索帮助