最新【JAVA问题解决方案】02,字节跳动大数据开发高级工程师

img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

public void excelTest(){
    List<Student> students = studentService.initFillData();
    int totalCount = students.size();
    Map<String,Object> data = new HashMap<String, Object>();
    data.put("studentList", students);
    data.put("totalCount",totalCount);
    try {
        //这里前面是模板位置,后面是生成的excel位置
        studentService.parse("D:\\study\\projecct\\freemarker\\src\\main\\resources\\templates\\", "Freemark.xml",
                "E:\\excel\\excelTest30.xls", data);
    } catch (IOException e) {
        e.printStackTrace();
    } catch (TemplateException e) {
        e.printStackTrace();
    }
}

}


项目样图:  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/49628f11fd074ebda66bb1e871994b35.png)


### Freemarker模板


**说明:**最重要的部分,可能会有些看不懂所以得了解Freemarker的语法才可以。excelCapacity 是表示多少条进行分页。



<?xml version="1.0" encoding="UTF-8" standalone="yes"?> <?mso-application progid="Excel.Sheet"?>



Apache POI
chenqingtao
2020-03-16T08:20:00Z
2022-11-03T07:31:58Z


9DC2DE9132B4460BB7A5E14BF585E55C
2052-11.1.0.12650


24225
12540
False
False

    <Style ss:ID="s49"/>
</Styles>

<#assign num = 0 />
<#assign forCount = 0/>
<#assign excelCapacity = 10/>
<#assign pages = 0/>
<#if totalCount % excelCapacity == 0>
<#assign pages = totalCount / excelCapacity />
<#else>
<#assign pages = (totalCount / excelCapacity) +1 />

</#if>

<#if totalCount gt excelCapacity>
<#list 1…pages as pageSize>

<Worksheet ss:Name=“表名称${pageSize?string(“number”)}”>

学生姓名 学生ID <#assign fromIndex = excelCapacity \* pageSize /> <#if fromIndex gte totalCount> <#assign fromIndex = totalCount />

<#list studentList[num…<fromIndex] as student>


s t u d e n t . n a m e < / D a t a > < / C e l l > < C e l l > < D a t a s s : T y p e = " N u m b e r " > {student.name}</Data> </Cell> <Cell> <Data ss:Type="Number"> student.name</Data></Cell><Cell><Datass:Type="Number">{student.id}


<#assign num=num+1 />
<#if num == fromIndex >
<#break>
</#if>
</#list>
<#assign num = fromIndex />

    </Table>
0 0 100 3 7 3 R8C4 False False

<#assign forCount = forCount +1/>
<#if forCount == pages>
<#break>
</#if>

    </#list>

<#else>

学生姓名 学生ID <#list studentList as student> ${student.name} ${student.id}
0 0 100 3 7 3 R8C4 False False
    </#if>
    </Workbook>

## 二、Freemarker常用语法


### 1.声明变量


在模板中可以定义三种类型的变量:


'‘简单’'变量: 它能从模板中的任何位置来访问,或者从使用 include 指令引入的模板访问。可以使用 assign 指令来创建或替换这些变量。因为宏和方法只是变量,那么 macro 指令 和 function 指令 也可以用来设置变量,就像 assign 那样。


局部变量:它们只能被设置在 宏定义体内, 而且只在宏内可见。一个局部变量的生命周期只是宏的调用过程。可以使用 local指令 在宏定义体内创建或替换局部变量。


循环变量:循环变量是由如 list 指令自动创建的,而且它们只在指令的开始和结束标记内有效。宏 的参数是局部变量而不是循环变量。


全局变量:这是一个高级话题了, 并且这种变量最好别用。即便它们属于不同的命名空间, 全局变量也被所有模板共享,因为它们是被 import进来的, 不同于 include 进来的。那么它们的可见度就像数据模型那样。 全局变量通过 global指令来定义。


示例:使用 assign 创建和替换变量:



<#assign x = 1> <#-- create variable x -->
${x}
<#assign x = x + 3> <#-- replace variable x -->
${x}


### 2.if elseif


你可以使用 if, elseif 和 else 指令来条件判断是否越过模板的一个部分。 condition 必须计算成布尔值, 否则错误将会中止模板处理。elseif 和 else 必须出现在 if 内部 (也就是,在 if 的开始标签和结束标签之间)。 if 中可以包含任意数量的 elseif(包括0个) 而且结束时 else 是可选的。比如:


只有 if 没有 elseif 和 else:



<#if x == 1>
x is 1
</#if>


只有 if 没有 elseif 但是有 else:



<#if x == 1>
x is 1
<#else>
x is not 1
</#if>


有 if 和两个 elseif 但是没有 else:



<#if x == 1>
x is 1
<#elseif x == 2>
x is 2
<#elseif x == 3>
x is 3
</#if>


有 if 和三个 elseif 还有 else:



<#if x == 1>
x is 1
<#elseif x == 2>
x is 2
<#elseif x == 3>
x is 3
<#elseif x == 4>
x is 4
<#else>
x is not 1 nor 2 nor 3 nor 4
</#if>




![img](https://img-blog.csdnimg.cn/img_convert/a05ba0bd8b56071eaf0251bcab3ed897.png)
![img](https://img-blog.csdnimg.cn/img_convert/606585f587d260df1d47eea307ed97a1.png)
![img](https://img-blog.csdnimg.cn/img_convert/40d6ee64815dd7b54337fd88c1491994.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**

..(img-kME21fGB-1715814692499)]
[外链图片转存中...(img-N2OcGclx-1715814692499)]
[外链图片转存中...(img-cfycE9ne-1715814692499)]

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**

  • 33
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值