赞
踩
hi,大家好,我是恰恰
阅读本文需要2分钟~
最近利用企业微信群机器人做的需求主要有
1.返奖率通知与告警:抽奖箱能抽出垃圾也能抽出大货,每隔5分钟查询一下这个返奖率,如果用户频繁抽出大货,这个抽奖箱的返奖率已经高出了阈值,那么我们就将其下架。
2.自动发送导表文件:关于运营每天都需要导表,我已俨然成为了一名导表侠,迫在眉睫我必须自我解放,所以可以利用机器人每天早上十点给运营们发送导表文件。
以自动发送导表文件为例 我需要把新注册的用户在平台消费大于等于50元的用户ID给到运营同学
开始写代码~
- /** 企业微信群上传文件url */
- public static final String UPLOAD_FILE_URL = "https://qyapi.weixin.qq.com/cgi-bin/webhook/upload_media?key=填你的机器人的key&type=file";
- /** 发送群消息url */
- public static final String SEND_MESSAGE_URL = "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=填你的机器人的key";
1.先筛选出消费大于等于50元用户的List,组装数据保存到电脑D盘(EasyUtil是一个把List导出到本地的工具)
- List<NewRegistrationUser> collect = resultList.stream().filter(r -> r.getOpenBoxAmount() + r.getDirectPurAmount() >= 50).collect(Collectors.toList());
-
- List<Map<String, Object>> list = new ArrayList<>();
- for (int i = 0; i < collect.size(); i++) {
- LinkedHashMap<String, Object> map = new LinkedHashMap<>();
- NewRegistrationUser user = collect.get(i);
- map.put("用户ID ", user.getUserId());
- map.put("付费金额", user.getOpenBoxAmount()+user.getDirectPurAmount());
- list.add(map);
- }
- List<String> arrayList = new ArrayList(list.get(0).keySet());
- //表头信息
- String head =date+"消费大于等于50元名单";
- EasyUtil.easyUtil(arrayList, head, list);
2.先将文件上传到企微的文件上传接口里去,使用hutool发送Post请求,他会返回一个media_id,
- String path = "D:\\导表\\" + head + ".xlsx";
- // 上传文件
- HashMap<String, Object> sendMap = new HashMap<>();
- sendMap.put("file", FileUtil.file(path));
- String result = cn.hutool.http.HttpUtil.post(UPLOAD_FILE_URL,sendMap);
- JSONObject jsonObject = JSON.parseObject(result);
- Integer errcode = Integer.valueOf(jsonObject.get("errcode").toString());
3.如果code返回0说明文件上传成功,进行下一步把文件推送到企微
- if (errcode.equals(0)) {
- // 推送消息
- String mediaid = (String) jsonObject.get("media_id");
-
- Map<String,Object> mediaMap = new HashMap<>();
- mediaMap.put("media_id",mediaid);
- Map<String,Object> msgMap = new HashMap<>();
- msgMap.put("msgtype","file");
- msgMap.put("file",mediaMap);
- cn.hutool.http.HttpUtil.post(SEND_MESSAGE_URL, JSON.toJSONString(paramMap));
4.再发送一句文字消息
- HashMap<String, Object> paramMap = new HashMap<>();
- HashMap<String, Object> aMap = new HashMap<>();
- String format = String.format("%s | %s | %d ", date, newRegistrationUser.size(), collect.size());
- aMap.put("content", "导表小助手来咯~"+"\n"+"时间 | 新注册人数 | 消费大于等于50人数 \n" + String.join("\n", format));
- msgMap.put("text",aMap);
- paramMap.put("msgtype", "text");
- paramMap.put("text", aMap);
- cn.hutool.http.HttpUtil.post(SEND_MESSAGE_URL, JSON.toJSONString(paramMap));
- }
效果就是这样的
5.如果是通知告警信息是个LIst就把文字组装成这样
- List<String> warnTexts = recordsList.stream().map(wi -> String.format("%s | %s | %d | %.2f%%", wi.getComboBoxId(), wi.getAdminUserName(),wi.getProfit(),wi.getProfitRate()).collect(Collectors.toList());
- HashMap<String, Object> paramMap = new HashMap<>();
- HashMap<String, Object> aMap = new HashMap<>();
- aMap.put("content", LocalDateTime.now() + "\n"+ "自动下架通知(请相关人员注意)~"+"\n" + "ID | 负责人 | 利润 | 利润率 \n" + String.join("\n", warnTexts));
- paramMap.put("msgtype", "text");
- paramMap.put("text", aMap);
- cn.hutool.http.HttpUtil.post(SEND_MESSAGE_URL, JSON.toJSONString(paramMap));
6.再写一个定时任务调一下咱们写的这个方法~就可以定时啦
- //每天上午10点执行任务
- @Scheduled(cron = "0 0 10 * * ?")
- public void NewUserAmount(){
- //拉取前一天的数据
- newUserAmountService.NewUserAmount(LocalDate.now().minusDays(1));
- }
ok,能帮助到你的话,给我点个赞哦!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。