5分钟实现 Java 使用 HanLP提取关键词短语 ;Vue实现词云图,词云图自定义形状,关键词绑定事件。
5分钟实现 Java 使用 HanLP提取关键词短语 ;Vue实现词云图,词云图自定义形状,关键词绑定事件。
1.Java使用HanLp提取关键词短语
首先HanLp是开源免费的,可以直接引入依赖
<dependency>
<groupId>com.hankcs</groupId>
<artifactId>hanlp</artifactId>
<version>portable-1.8.4</version>
</dependency>
小伙伴们如果有兴趣可以查看官方文档,写的非常详细,我这里就是用的 关键词提取的功能
示例代码如下:
String content = "世嘉:《索尼克:超级巨星》销量不佳与《马里奥惊奇》撞车有关";
List<String> keywordList = HanLP.extractKeyword(content, 2);
System.out.println(keywordList);
官方文档:
2.Vue实现词云图
先看效果:
那么我们如何实现如上的词云图呢?直接上代码:
setWordChart = function (detail) {
const that = this;
if (that.$refs.wordChart) {
// 如果已经初始化,则销毁图表实例
echarts.dispose(this.$refs.wordChart);
}
// 获取 chart 元素
const chartDom = that.$refs.wordChart;
// 初始化 echarts
const myChart = echarts.init(chartDom);
//let data = Object.entries(detail).map(([name, value]) => ({name, value}));//这个detail就是你自己通过handlp获取到的关键词存储到了数据库,通过后端数据库查询到的值传过来来的,我这里是传了一个map回来,关键词和值的key-value形式
// 示例数据
let data = [
{ value: 60, name: '运量' },
{ value: 41, name: '延安路' },
{ value: 37, name: '公交' },
{ value: 35, name: '中运量' },
{ value: 15, name: '申昆路' },
{ value: 14, name: '路' },
{ value: 13, name: '上海' },
{ value: 11, name: '车道' },
{ value: 10, name: '电车' },
{ value: 10, name: '终点站' },
{ value: 9, name: '公交车' },
{ value: 9, name: '专用道' },
{ value: 9, name: '载客' },
{ value: 8, name: '无轨电车' },
{ value: 7, name: '开通' },
{ value: 7, name: '外滩' },
{ value: 7, name: '专用' },
{ value: 5, name: '线路' },
{ value: 5, name: '全文' },
{ value: 5, name: '延安东路' },
{ value: 4, name: '延安西路' },
{ value: 4, name: '试运行' },
{ value: 3, name: 'brt' },
{ value: 3, name: '高架' },
{ value: 3, name: '司机' },
{ value: 3, name: '运营' },
{ value: 3, name: '枢纽站' },
{ value: 2, name: '联调' },
{ value: 2, name: '区间' },
{ value: 2, name: '巴士' },
{ value: 2, name: '巨龙' },
{ value: 2, name: '中山东一路' },
{ value: 2, name: '车辆' },
{ value: 2, name: '虹桥' },
{ value: 2, name: '青平公路' },
{ value: 2, name: '乘坐' },
{ value: 2, name: '巨龙车' },
{ value: 2, name: '乘客' },
{ value: 2, name: '线网' },
{ value: 2, name: '通车' },
{ value: 2, name: '车站' },
{ value: 2, name: '去外滩' },
{ value: 2, name: '空载' },
{ value: 2, name: '尝鲜' },
{ value: 2, name: '红灯' },
{ value: 2, name: '体验' },
{ value: 2, name: '安东路外滩' },
{ value: 2, name: '试车' },
{ value: 2, name: '速递' },
{ value: 2, name: '站台' },
{ value: 2, name: '延安' },
{ value: 1, name: '西藏' },
{ value: 1, name: '客流' },
{ value: 1, name: '车厢' },
{ value: 1, name: '上海·七莘' },
{ value: 1, name: '长宁' },
{ value: 1, name: '恶臭' },
{ value: 1, name: '娄山关' },
{ value: 1, name: '天桥' },
{ value: 1, name: '红绿灯' },
{ value: 1, name: '正式' },
{ value: 1, name: '路权' },
{ value: 1, name: '新片' },
{ value: 1, name: '视频' },
{ value: 1, name: '头班车' },
{ value: 1, name: '中路' },
{ value: 1, name: '北路站' },
{ value: 1, name: '传说' },
{ value: 1, name: '小时' },
{ value: 1, name: '路试' },
{ value: 1, name: '单程' },
{ value: 1, name: '路上' },
{ value: 1, name: '拥堵' },
{ value: 1, name: '启用' },
{ value: 1, name: '换乘' },
{ value: 1, name: '调试' },
{ value: 1, name: '中门' },
{ value: 1, name: '凯旋路' },
{ value: 1, name: '候车' },
{ value: 1, name: '双流路' },
{ value: 1, name: '上班' },
{ value: 1, name: '天山路' },
{ value: 1, name: '交通委' },
{ value: 1, name: '市民' },
{ value: 1, name: '发车' },
{ value: 1, name: '上车' },
{ value: 1, name: '开车' },
{ value: 1, name: '驾驶员' },
{ value: 1, name: '路线' },
{ value: 1, name: '样车' },
{ value: 1, name: '华山路' },
{ value: 1, name: '缩线' },
{ value: 1, name: '铰接' },
{ value: 1, name: '马路' },
{ value: 1, name: '凑热闹' },
{ value: 1, name: '高峰' },
{ value: 1, name: '中路站' },
{ value: 1, name: '你好' },
{ value: 1, name: '外滩站' }
]
//因为这里我采用了自定义形状的方式,数据太少,展示不出具体的形状,所以我就把数据扩大了,大家可以结合自身业务情况选择用不用自定义形状
data = [...data,...data,...data,...data]
//词云图自定义形状
const maskImage = new Image();
//五角星形状 图片可以转Base64,也可以你引入到的项目中直接获取
maskImage.src=''
//爱心形状 //maskImage.src=''
// 配置项
const option = {
series: [{
type: 'wordCloud',
shape: 'roundRect',
maskImage: maskImage,
sizeRange: [10, 30],//设置关键词字体大小
rotationRange: [0, 0],
rotationStep: 45,
gridSize: 10,//设置间隔距离
drawOutOfBound: false,
data: data,
height:'100%',//这里你如果使用自定义的形状,必须保证你的高度足够和宽度足够
width:'100%',
textStyle: {
color: function() {
// Random color
return 'rgb(' + [
Math.round(Math.random() * 160),
Math.round(Math.random() * 160),
Math.round(Math.random() * 160)
].join(',') + ')'
}
},
emphasis: {
focus: 'self', // 设置词云图的 emphasis 样式
textStyle: {
shadowBlur: 10,
shadowColor: '#333'
},
}
}],
};
// 设置图表配置项
maskImage.onload =function (){
myChart.setOption(option);
}
myChart.on('click', function (params) {
that.keyword = params.data.name
that.doSearch()
});
}
注意事项:
1.要使用echats的词云图,需要先前端下载 echarts-wordcloud,下载方式 npm install echarts-wordcloud;
2.小伙伴如果要自己找另外的形状,可以去阿里巴巴矢量图标库里面找,直接下载为png的图片就好了,但是我建议最好不要用线性的图标,因为线性的图可能很难出现你需要的效果,就是页面上不报错,词云图就是一片白板,其实是出现了,但是跟图标形状有关,有的词直接就超出你的范围,就看不到了,我建议用填充(filling)的矢量图,图标库链接如下:
3. 图片下载好了之后,可以有两个选择
1.图片转Base64,可以去这个转化网站,进行转化,链接如下:base64图片在线转换工具 - 站长工具 (chinaz.com)https://tool.chinaz.com/tools/imgtobase/
然后复制转化出来的链接,maskImage.src='你转化出来的链接'
2.如果不想转Base64也是可以的,直接把图片放到你的项目的某个资源包下面,然后获取地址,比如 maskImage.src= require('./image/star.png'),最好用上require,不然有可能你是获取不到那个图片的。
4.词云图里面的每个关键词是可以绑定点击事件的,我这里就绑定了一个事件,用来查询与关键词相关的数据,代码如下:
myChart.on('click', function (params) {
that.keyword = params.data.name
that.doSearch()
});
这里要注意的是你当前如果直接使用this的话,是调用不到你外面的其他方法的,你需要指定最开始的this,所以我在最上面定义了 const that = this,这样通过that.方法名()就可以调用啦。
总结:通过如上的操作就可以实现我们上面的效果啦,希望能帮到各位小伙伴!
更多推荐
所有评论(0)