https://github.com/mozillazg/go-pinyin.git

evan.hong fda20c9f20 init 3 роки тому
.github fda20c9f20 init 3 роки тому
_tools fda20c9f20 init 3 роки тому
cmd fda20c9f20 init 3 роки тому
.editorconfig fda20c9f20 init 3 роки тому
.gitignore fda20c9f20 init 3 роки тому
.gitmodules fda20c9f20 init 3 роки тому
.travis.yml fda20c9f20 init 3 роки тому
CHANGELOG.md fda20c9f20 init 3 роки тому
LICENSE fda20c9f20 init 3 роки тому
Makefile fda20c9f20 init 3 роки тому
README.md fda20c9f20 init 3 роки тому
benchmark_test.go fda20c9f20 init 3 роки тому
doc.go fda20c9f20 init 3 роки тому
example_test.go fda20c9f20 init 3 роки тому
go.mod fda20c9f20 init 3 роки тому
phonetic_symbol.go fda20c9f20 init 3 роки тому
pinyin.go fda20c9f20 init 3 роки тому
pinyin_dict.go fda20c9f20 init 3 роки тому
pinyin_test.go fda20c9f20 init 3 роки тому

README.md

go-pinyin

Build Status Coverage Status Go Report Card GoDoc

汉语拼音转换工具 Go 版。

Installation

go get -u github.com/mozillazg/go-pinyin

install CLI tool:

go get -u github.com/mozillazg/go-pinyin/cmd/pinyin
$ pinyin 中国人
zhōng guó rén

Documentation

API documentation can be found here: https://godoc.org/github.com/mozillazg/go-pinyin

Usage

package main

import (
	"fmt"
	"github.com/mozillazg/go-pinyin"
)

func main() {
	hans := "中国人"

	// 默认
	a := pinyin.NewArgs()
	fmt.Println(pinyin.Pinyin(hans, a))
	// [[zhong] [guo] [ren]]

	// 包含声调
	a.Style = pinyin.Tone
	fmt.Println(pinyin.Pinyin(hans, a))
	// [[zhōng] [guó] [rén]]

	// 声调用数字表示
	a.Style = pinyin.Tone2
	fmt.Println(pinyin.Pinyin(hans, a))
	// [[zho1ng] [guo2] [re2n]]

	// 开启多音字模式
	a = pinyin.NewArgs()
	a.Heteronym = true
	fmt.Println(pinyin.Pinyin(hans, a))
	// [[zhong zhong] [guo] [ren]]
	a.Style = pinyin.Tone2
	fmt.Println(pinyin.Pinyin(hans, a))
	// [[zho1ng zho4ng] [guo2] [re2n]]

	fmt.Println(pinyin.LazyPinyin(hans, pinyin.NewArgs()))
	// [zhong guo ren]

	fmt.Println(pinyin.Convert(hans, nil))
	// [[zhong] [guo] [ren]]

	fmt.Println(pinyin.LazyConvert(hans, nil))
	// [zhong guo ren]
}

注意:

  • 默认情况下会忽略没有拼音的字符(可以通过自定义 Fallback 参数的值来自定义如何处理没有拼音的字符, 详见 示例)。
  • 根据 《汉语拼音方案》 y,w,ü (yu) 都不是声母, 以及不是所有拼音都有声母,如果这不是你预期的话,你可能需要的是首字母风格 FirstLetter详细信息 )。

Related Projects

pinyin data

License

Under the MIT License.