excel格式讲解 excel格式讲解新版的excel文件,本质是一个zip压缩包,将其解压后,能看到其内部结构。 解压文件目录找一个excel.xlsx文件,将其进行解压,目录结构如下 打开xl文件夹,styles.xml存储了全局的样式,worksheets内的sheet存储了每个sheet的数据,theme存储主题,shardStrings.xml存储的字符串池。 打开sheet.xml,其结构如下 row 2021-10-12 #java #excel
excel直接打开看到的日期格式和poi读取到的日期格式不一样 excel直接打开看到的日期格式和poi读取到的日期格式不一样现象: 创建一个excel.xlsx文件,输入一个日期,将其格式选择为自定义类型 yyyy/m/d h:mm 并保存 可以看到,日期格式确实变成了类似于2021/1/10 1:15的样子 使用poi读取该文件,发现读取到的该单元格的数据为m/d/yy h:mm格式,并不是上面在 2021-10-12 #java #excel #poi
aws s3 预签名上传文件,下载文件 aws s3 预签名上传文件,下载文件需求是生成预签名下载链接,将链接发送给没有s3权限的用户,其也能正常下载而不需要登录到aws。上传也是同理,生成预签名上传链接,用户上传时无需登录aws。 1.引入jar包1234567891011121314 <dependency> <groupId>software.amazon.awssdk</grou 2021-10-11 #aws #s3
groovy闭包 list传参 groovy闭包 list传参 问题现象如下代码,定义一个闭包接受两个参数,传递参数时可以传递 size = 2 的 List 作为参数, 使用 length = 2 的数组不可以,使用 size = 2 的 Set 也不可以。 12345678910111213@Test void test2() { def closure = 2021-07-17 #groovy #闭包
mybatis-generator多个数据库存在相同的表 mybatis-generator多个数据库存在相同的表 问题现象使用mybatis时难免会使用其提供的mybatis-generator生成默认的xml和实体类,今天我发现如果本地安装一个mysql,里面创建两个不同的数据库,而他们有相同的表,生成的实体类中可能是随机的。比如我有一个数据库 ‘a’ 里面有一张表 ‘user’,我现在在建一个库‘b’,里面也有一张表‘user’,这样我生成代码时 2021-07-17 #bug #mybatis #generator
mysql使用updatetime作为乐观锁 mysql使用updatetime作为乐观锁本文记录一下,我是用mysql的updatetime字段作为乐观锁版本号遇到的问题。 乐观锁首先标准的乐观锁,应该存在一个version字段,每次更新时人工自增此字段,但是这样每次更新时都要多维护一个字段很麻烦。所以我使用数据库中的update_time字段作为乐观锁的version使用,将update_time字段设为每次有更新时自动刷新,使用此字段当 2021-07-01 #mysql #bug #乐观锁
spock测试零基础教程 spock测试零基础教程 昨天研究了一下spock单元测试,确实特别好用,这也是我第一次接触spock,作为一个新手,网上很多教程讲的太深了,折腾了好几个小时才搞明白。 所以我想写一个从0开始的简单教程,一步一步做把Demo跑起来,再去看其他人的教程,这样更有效率。 下面我将基于spock2.x版本进行演示。可以新建一个空SpringBoot项目进行测试,防止项目内的其他依赖冲突,Demo 2021-07-01 #spock #单元测试
spring非单例模式 spring非单例模式 一般情况下,使用spring的bean都是单例模式的,默认情况下就是如此。单例模式的bean都是无状态的,但是面对复杂场景下,希望bean内能存储状态,这种情况下就不能够使用单例模式了。 spring提供了 @Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE) 注解,可以选择是单例模式还是每次使用都创建一个,用法如下。 下面提供 2021-06-28 #spring #原型 #prototype #objectProvider #objectFactory
spring项目,外部文件读取 spring,文件读取spring内置了不错的文件读取工具类,下面讲一下其用法 1.读取classpath下文件 文件路径以classpath:开头,这种方式可以读取resources文件夹下的资源 123456789101112131415161718192021222324 public static void main(String[] args) throws IOExcepti 2021-06-28 #spring #FileSystemResourceLoader #ResourceLoader #文件读取
prometheus函数的理解 prometheus函数的理解最近在研究prometheus,花了一天时间理解了几个主要函数的原理,现在记录以下,给以后的自己看rate()函数这个函数接受一个范围counter序列,他能返回每秒钟的qps,因为counter是单调递增的,我才他是将最后一个记录的值减去第一个记录的值,再除以时间段的总秒数得到一个浮点型数字,表示每秒增长的数量。这个函数只能返回每秒的数量,如果需要每分钟的可以自己乘 2021-05-01 #prometheus #grafana