“This is the 21st day of my participation in the First Challenge 2022. For details: First Challenge 2022”

👨🎓 Author: Bug Bacteria

✏️ blog: CSDN, Nuggets, etc

💌 public account: Magic House of the Circle of the Apes

🚫 special statement: original is not easy, reprint please attach the original source link and this article statement, thank you for your cooperation.

🙏 Copyright notice: part of the text or pictures in the article may come from the Internet or Baidu Encyclopedia, if there is infringement, please contact bug bacteria processing.

Hi, family. I’m the bug. Here I go again. Today we are going to talk about something, OK, and we will continue the Series of articles on SpringBoot. Hope to help more beginners quickly start!

In the process of reviewing articles, if you think the articles are helpful to you at all, please don’t be too mean with your likes and bravely light up the articles 👍. Your likes (collect ⭐️+ pay attention to 👨 port + message board) are the best encouragement and support for bugs on my creation path. Time does not abandon 🏃🏻♀️, creation stopped 💕, refueling 🏻

One, foreword

In the last few sessions, we mainly talked about how to integrate EasyPOI to implement excel import and export functions, right? I don’t know how you have mastered it. If you still have questions about any of the following articles, please ask more questions. Ha ha ha, although I am not a big guy, I will try my best to teach each other and learn to fill in the gaps together.

  • How does Springboot integrate with EasyPOI

  • Integrate EasyPOI to realize Excel import function

  • Integrated EasyPOI to achieve Excel export function

  • Integrated EasyPOI to achieve a single Word template to generate multi-page data

  • Integrated easyPOI to export multiple data in word template

For last time, we talked about how to implement word template export to generate multi-page data, such as the following screenshot:

Export right, but in addition to the above more page, I also took a demand is needed to show all the data within a template, like this kind of situation, our previous interpretation, it is not so suitable, so this period, I will talk about, how within a word templates iterates through all of the output data, has the very good learning value, Listen up, everybody.

2. Introduce POM dependencies

Because EasyPoi can easily pass a Word template, and then generate the word document we want by filling the template. So today we are still based on easyPOI to achieve a Word template traversal output all the data.

<! - easypoi dependence, Afterturn </groupId> <artifactId>easypoi-spring-boot-starter</artifactId> The < version > 4.2.0 < / version > < / dependency >Copy the code

Three, to achieve word export

1. Define a Word template file

I’ll do it as a user class, so I’ll create a table in Word that prints out all the user details. So I specified the following word template file:

Development:

The template contains the normal tags and fe traversal, FE traversal, FE traversal, FE traversal is probably the most widely used traversal, it’s used to deal with traversal and then there’s the processing of the data and what we’re going to generate is this and we’re going to need some list set and some pure data.

Fe writing:

Syntax: FE marks colon list data single element data (default t, can be omitted) the first element

Examples are shown below for reference:

{{$fe: userList t t.id }}
Copy the code

UserList corresponds to the Map key that contains list in the Map of exportWord07(String URL, Map

Map) passed to your code.
,>

See the following for details:

2. Add word export method for Controller

Let’s first define a Word document export method, the purpose is to provide a port, easy to test through the browser access.

@getMapping ("export-word-all") @apiOperation (value = "Export word to a template ", Notes = "Export word document to a template ") public void exportUsersToWordAll(HttpServletResponse Response) throws Exception { userService.exportUsersToWord(response); }Copy the code

You don’t need any return values or arguments, you just need to carry the HttpServletResponse that you requested when you called the interface.

3. Define the import interface

/** * Word document export to a template */ void exportUsersToWordAll(HttpServletResponse Response) throws Exception;Copy the code

4. Implement the export method (core)

The following export implementation class is very key, we still directly use easyPOi provides exportWord07() method, this method can be your data assignment into the specified Word template, but involves the internal traversal problem, or word export assignment method is not quite the same. Please refer to the details I wrote:

The specific code Settings are as follows:

*/ @override public void exportUsersToWord(HttpServletResponse Response) throws Exception { Map<String, Object> mapList = new HashMap<>(); List<Map<String, Object>> listUsers = new ArrayList<>(); List<UserEntity> users = this.list(); // Set an atomic integer. AtomicInteger i= new AtomicInteger(1); // Add a loop to a collection. users.forEach(user -> { Map<String, Object> map = new HashMap<>(); Map.put ("id", i.getandincrement ()); map.put("name", user.getName()); map.put("age", user.getAge()); map.put("sex", user.getSex()); map.put("address", user.getAddress()); map.put("describes", user.getDescribes()); // To add a map to the collection, a line is listusers.add (map); }); // Add to return set maplist. put("users", listUsers); // set class to maplist. put("class", "class 1 "); // Set the operator to maplist. put("operator","admin"); // Set the current time maplist. put("createTime","2022/02/17"); / / export word and specify the word export template XWPFDocument doc. = WordExportUtil exportWord07 (". / template/users to export template _all. Docx ", mapList); / / set the coding format response. SetCharacterEncoding (StandardCharsets. UTF_8. Name ()); // Set the content type response.setContentType("application/octet-stream"); // Set the header and file name. response.setHeader("Content-Disposition", "attachment; Filename =" + URLEncoder. Encode (" student.docx ", standardCharsets.utf_8.name ())); / / write doc. Write (response. GetOutputStream ()); }Copy the code

The important thing to note in the code above is that there are two types of assignment, one where map adds a base data type, and one where Map adds a collection. This is how data is evaluated in your Word template.

5. Browser test interface

We open the browser, enter the address of the interface we just exposed in Controller in the address bar:

Like me: http://localhost:8080//user/export-word-all you for a visit at your interface address.

You can see that a file is being downloaded, and the rest is to see if the content has been backfilled.

When you see the screenshot above, do you think it is better than the mode of generating multiple pages from a single template in my last issue? Great, no? Then the single value and traversal value we set are rendered in Word.

We can also compare, the last generation of a single template multi-page Word mode, depending on your needs to achieve that way, use that.

ExportWord07 () is called in the export word traversal as a template, adding a map for nesting, as well as the template writing method! This requires special attention, write the wrong template can not get the value.

In fact, you can also use a single template to write the same as the current template, but the current template only applies to the field in each column, if the row display! No, that’s what you need to be aware of.

The following is an overloading of the exportWord07() method, which can be applied to multiple data types, thus laying the foundation for the data loop we can implement.

exportWord07(String url, Map<String, Object> map)

exportWord07(String url, List<Map<String, Object>> list)
Copy the code

. .

Well, that’s all for this episode, and if you want to learn more, you can check out my top tips on how to accumulate a little weird knowledge every day, and over time, you can become a person you respect. Well, I’ll see you next time

Four, the past popular recommendation

  • Springboot series (16) : Integrated easyPOI implementation of Excel import and export (preparation)

  • Springboot series (16) : Integrated easyPOI to achieve Excel import

  • Springboot series (16) : Integrated easyPOI to achieve Excel export

  • Springboot series (16) : integrated easyPOI to achieve a single Word template export page

  • Springboot series (16) : Integrated easyPOI to realize word template circulation export multiple data

  • Springboot series (16) : Integrated easyPOI word template image export

  • Springboot series (15) : AOP implements custom annotations for business logging! Have you ever played?

  • Springboot series (14) : Redis Zero-based teaching, you deserve it!

  • Springboot Series (thirteen) : How to project integrated Swagger online interface documentation, will you?

  • Springboot series (12) : How to code to send email reminders, have you written?

  • . .

If you want to learn more, you can pay attention to the bug bug column “SpringBoot Zero-based Introduction”, from scratch, from zero to one! Hope I can help you.

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *

☘️ Be who you want to be, there is no time limit, you can start whenever you want,

🍀 You can change from now on, you can also stay the same, this thing, there are no rules to speak of, you can live the most wonderful yourself.

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *

💌 If this article is helpful to you, please leave a like! (# ^. ^ #);

💝 if you like the article shared by bug fungus, please give bug fungus a point of concern! The danjun ‘ᴗ, you guys will have a cameo appearance with you.

💗 if you have any questions about the article, please also leave a message at the end of the article or add a group [QQ communication group :708072830];

💞 In view of the limited personal experience, all views and technical research points, if you have any objection, please directly reply to participate in the discussion (do not post offensive comments, thank you);

💕 copyright notice: original is not easy, reprint please attach the original source link and this article statement, all rights reserved, piracy will investigate!! thank you