大家好,我叫谢伟,是一名程序员。
如何你经常逛 Github,发现很多人的项目写的 简介图文并貌,有很多的表情。当然说到表情,我们在手机上也存在很多的 emoji 表情,这些表情极大的丰富了我们的内容。
所以,趁着空闲,写了下面一款支持 emoji 表情的库:
主要的用法如下:
package main
import (
"github.com/wuxiaoxiaoshen/go-emoji/emoji"
)
func main() {
emj := emoji.NewEmoji()
emj.Println(":grinning:")
emj.Println(":fire:")
emj.Println(":100:")
emj.Println(":bookmark:")
fmt.Println(emj.Length())
}
>>
支持的API 如下:
- NewEmoji
初始化操作
emo := emoji.NewEmoji()
- ShortCodeList
获取所有的 shortCode
fmt.Println(emo.ShortCodeList())
- CodePoints
获取所有的 codePoints
fmt.Println(emo.CodePoints())
- Println
- Printf
- Fprint
- Fprintln
- Fprintf
- Sprint
- Sprintf
- Errorf
输出
for _, i := range emo.ShortCodeList() {
emo.Println(i)
}
for _, i := range emo.ShortCodeList() {
fmt.Println(emo.Exists(i))
}
for _, i := range emo.ShortCodeList() {
emo.Sprintf("%#v", i)
}
for _, i := range emo.ShortCodeList() {
emo.Sprint(i)
}
- Random
随机得出一个emoji
- Length
支持的 emoji 的个数
- Exists
根据 short code 判定是否支持 emoji
整体思路:
- 既然是一款 emoji 表情库,那么得知道存在哪些表情,所以利用爬虫从目标网站 搜集码点和缩写
- 搜集完成之后,我们怎么才可以通过缩写或者码点得出表情呢?
主要的思路如下:将码点转换为 16 进制,再调用 html.UnescapeString 方法进行输出
package main
import "fmt"
import "strconv"
import "html"
func main(){
x , _ := strconv.ParseInt("1F600", 16, 64)
str := html.UnescapeString("" + strconv.Itoa(int(x)) + ";")
fmt.Println(str)
}
- 知道了这些简单的原理之后,我们后续的操作,就是通过搜集的表情的缩写和码点不断的丰富,所以衍生出了上文提到的 API
- 缺点:这种方式只支持存在 缩写且表情是单码点的情况,有一些复杂的多码点的emoji 表情并不能完全处理
项目地址:https://github.com/wuxiaoxiaoshen/go-emoji
欢迎试用。
<完>