如何把一个基于Maven项目所有的jar文件快速列出到Excel?

来源:互联网 发布:产品矩阵是什么意思 编辑:程序博客网 时间:2024/06/05 01:04

我们在做项目的时候,有的时候根据公司法务部门的要求,我们需要把项目中用到的所有的jar文件,整出一个Jar文件的列表,如果项目比较小的话,还好说,如果项目比较大的话,就比较麻烦了,因为jar包之间是有直接和间接依赖的。比如在Maven的配置文件里显式申明了A的依赖,但是A的依赖又可能依赖于B,C,D等。
那么有没有一种方法可以很方便的列出其项目中用到的所有的jar呢?且能够很快速的导入到Excel里面来?
假设其Pom.xml文件中的依赖如下:

    <parent>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-parent</artifactId>        <version>1.2.3.RELEASE</version>        <relativePath/> <!-- lookup parent from repository -->    </parent>    <properties>        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>        <start-class>com.winterbe.react.Application</start-class>        <java.version>1.8</java.version>    </properties>    <dependencies>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-web</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-tomcat</artifactId>        </dependency>        <dependency>            <groupId>org.apache.tomcat.embed</groupId>            <artifactId>tomcat-embed-jasper</artifactId>        </dependency>        <dependency>            <groupId>javax.servlet</groupId>            <artifactId>jstl</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-test</artifactId>            <scope>test</scope>        </dependency>        <dependency>            <groupId>org.jsoup</groupId>            <artifactId>jsoup</artifactId>            <version>1.7.3</version>            <scope>test</scope>        </dependency>    </dependencies>
1. 首先使用maven的命令,把项目所有的依赖导出到一个txt文件,命令如下.
mvn dependency:tree -Doutput=1.txt

生成的1.txt文件如下:
这里写图片描述

2.打开编辑器,把所有的+,-,空格替换掉,1分钟左右,很快替换成下面的样子

这里写图片描述

3.把所有的”:”替换成“,”,并把1.txt后缀名改成1.csv,打开后如下,并删除

红色标出的行和列

这里写图片描述

4. 用Excel的公式生成jar文件名称

这里写图片描述

5. 复制黏贴出来

在Excel里面,通过计算公式计算出的结果,如果直接拷贝是得不到文本的。
需要一个小技巧,那就是选择原值黏贴,请参考下图。
这里写图片描述

结果终于做出来,该歇口气了。

阅读全文
1 0