提取swagger内容到csv表格,excel可打开
swagger生成的页面api接口统计,有几种方法
- 直接在前端用js提取出来,较麻烦(不推荐,不同版本的页面生成的标签有可能不一样,因此可能提取不出来)
//apilet a = document.getElementsByClassName("opblock-summary-path");var temp = "";for(var i=0;i<a.length;i++){ temp += "\n" + a[i].getElementsByTagName("span")[0].innerText}
//请求方法let b = document.getElementsByClassName("opblock-summary-method");var temp = "";for(var i=0;i<b.length;i++){ temp += "\n" + b[i].innerText}
//描述let c = document.getElementsByClassName("opblock-summary-description");var temp = "";for(var i=0;i<c.length;i++){ temp += "\n" + c[i].innerText}
- 用页面自带的api-doc中的json数据,解析数据后直接生成csv表格,需要编程
public class JsonToTxtApplication {
public static void main(String[] args) throws IOException {
SpringApplication.run(JsonToTxtApplication.class, args);
FileInputStream in = new FileInputStream("1.txt");
JsonNode jsonNode = new ObjectMapper().readTree(in);
/**
* 取所有数据并存到HashMap中
*/
String api;
HashMap<String, List<Root>> hm = new HashMap<>();
JsonNode node = jsonNode.findValue("paths");
Iterator<String> stringIterator = node.fieldNames();
while (stringIterator.hasNext()) {
JsonNode tags = node.findValue((api = stringIterator.next())); //api
Iterator<String> methodsname = tags.fieldNames();
while (methodsname.hasNext()) {
String method = methodsname.next(); //方法
JsonNode methods = tags.findValue(method);
String name = methods.findValue("tags").get(0).asText();
String description = methods.findValue("description").asText();
Root root = new Root(name, method, api,description); //当前查询到的一个接口数据
//放到hashmap里管理
if (hm.containsKey(root.getName())) {
List<Root> roots = hm.get(root.getName());
roots.add(root);
hm.put(root.getName(), roots);
} else {
ArrayList<Root> roots = new ArrayList<>();
roots.add(root);
hm.put(root.getName(), roots);
}
}
}
/**
* 获得name的顺序,并按顺序写入csv
*/
File file = new File("result.csv");
BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(
new FileOutputStream(file), "GBK")); //excel不能读取utf-8编码的csv文件
Iterator<JsonNode> names = jsonNode.findValue("tags").iterator();
while (names.hasNext()) {
String name = names.next().findValue("name").asText();
Iterator<Root> iterator1 = hm.get(name).iterator();
bufferedWriter.write(name + ",");
Boolean isFirst = true;
while (iterator1.hasNext()) {
//如果是第一行增加name,如果不是填入空白格
if (!isFirst) {
bufferedWriter.write(",");
} else {
isFirst = false;
}
Root next = iterator1.next();
bufferedWriter.write(next.getMethod() + "," +
next.getApi() + "," + next.getDescription());
bufferedWriter.newLine();
}
}
bufferedWriter.close();
//打开生成的csv文件
Runtime.getRuntime().exec("cmd /c start F:/Project/JsonSoup/result.csv");
System.out.println("done");
}
}
- 还可以利用xpath helper提取,需要学习一下xpath语法,还需要安装浏览器插件xpath helper。一些环境要求不能安装软件时该方法不适用。其实这种方法跟js提取是一样的,区别就在于xpath提取更加简便快捷。
提取swagger内容到csv表格,excel可打开的更多相关文章
- Python 操作csv和excel表格
1. 操作csv表格 使用的库 csv 1. csv文件里读取数据 代码 1. 以列表形式打开 import csv f = open('csv_test.csv', 'r') # 打开csv文件 c ...
- csv表格处理(上)-- JS 与 PHP 协作导入导出
CSV简介 在开发后台管理系统的时候,几乎无可避免的会遇到需要导入导出Excel表格的需求.csv也是表格的一种,其中文名为“逗号分隔符文件”.在Excel中打开如下图左边所示,在记事本打开如下图右边 ...
- Unity 读取CSV与Excel
前几天看到我们在游戏中需要动态加载某些角色的游戏策划值,关于这个问题怎么解决呢?其实办法很多种,归根到底,就是数据的读取.我们可以想到的存储数据的载体有很多.例如:txt,xml,csv,excel. ...
- csv和excel互转
Python csv转换为excel学习笔记: openpyxl模块需要安装pip install openpyxl import openpyxl import csv '''读取csv文件写入ex ...
- csv表格处理(下)--纯JS解析导入csv
多日前的上篇介绍了csv表格,以及JS结合后端PHP解析表格填充表单的方法.其中csv转换成二维数组的时候逻辑比较复杂多坑,幸好PHP有丰富的库函数来处理,而现在用JS解析的话就没有那么幸运了,一切都 ...
- PHP处理CSV表格文件的常用操作方法是怎么样呢
php来说,fgetcsv读入csv表格,返回一个数组,然后foreach输出成HTML的<table>,这步操作几行代码就能实现,非常简单.工作量主要还在于浏览器前端,建议你用jQuer ...
- 15、解决14中csv用excel打开乱码的问题 open('zhihu.csv','w',newline='',encoding='utf-8-sig')
解决14中csv用excel打开乱码的问题 ,其实就是在写csv的时候把 utf-8 改成 utf-8-sig open('zhihu.csv','w',newline='',encoding='ut ...
- C# 读取CSV和EXCEL文件示例
我们习惯了直接连到数据库上面读取数据表的数据内容: 如果有一天我们需要读取CSV,EXCEL文件的内容的时候,可不可以也像读数据表的方式一样呢?当然可以,使用OleDB ADO.NET是很简单的事情 ...
- 第十七篇:csv拆分、csv转excel方法
首先对微软的office功能表示敬佩!可能是这些办公软件太过平常化,所以体会不到他有多牛!csv格式数据以前没接触过,百度百科定义,Comma-Separated Values,CSV,逗号分隔值,或 ...
随机推荐
- IDEA下Git分支开发
IDEA下Git分支开发使用 1.新建本地开发分支 VCS-->git-->branches-->New Branch,输入分支名字,如branch_test,点击OK后本地开发分支 ...
- JAVA知识点 I/O流框架简要笔记
I/O 框架 流的概念 内存与存储设备之间传输数据的通道 流的分类 按方向[重点] 输入流:将<存储设备>中的内容读到<内存>中 输出流:将<内存>中的内容写到&l ...
- [SSM项目]二-项目设计和框架搭建
一 10个实体类 选择Integer 而不是int的原因 :当值为空时,int类型会自动为其初始化,这是我们不希望的. 二 配置Maven 目录结构: src/main/java:业务代码 src/m ...
- 使用Java Stream,提取集合中的某一列/按条件过滤集合/求和/最大值/最小值/平均值
不得不说,使用Java Stream操作集合实在是太好用了,不过最近在观察生产环境错误日志时,发现偶尔会出现以下2个异常: java.lang.NullPointerException java.ut ...
- Github上如何添加 LICENSE 文件?
什么是开源软件? 开源软件是所有人都可以修改和补充的软件,因为开源软件的 license 协议允许这样做. Git版本控制系统就是开源的软件. 实际上开源软件的一个重要组成部分就是添加 license ...
- hystrix源码之AbstractCommand
AbstractCommand HystrixCommand和HystrixObservableCommand的父类.每个command对应一个HystrixCommandKey.HystrixThr ...
- Golang的Context介绍及其源码分析
简介 在Go服务中,对于每个请求,都会起一个协程去处理.在处理协程中,也会起很多协程去访问资源,比如数据库,比如RPC,这些协程还需要访问请求维度的一些信息比如说请求方的身份,授权信息等等.当一个请求 ...
- shellcode生成框架
因为vs编译后自己会生成很多东西,我们稍微配置下 先获取kernel32基址 __declspec(naked) DWORD getKernel32() { __asm { mov eax, fs:[ ...
- Codeforces1146G. Zoning Restrictions
Description You are planning to build housing on a street. There are n spots available on the street ...
- 使用kind搭建kubernetes
使用kind搭建kubernetes 目录 使用kind搭建kubernetes kind架构 创建集群 将镜像加载到kind的node中 配置kind集群 配置多节点 多控制面 指定Kubernet ...