Java導出帶格式的Excel數據到Word表格

来源:https://www.cnblogs.com/unsoleil/archive/2022/09/29/16742075.html
-Advertisement-
Play Games

在Word中創建報告時,我們經常會遇到這樣的情況:我們需要將數據從Excel中複製和粘貼到Word中,這樣讀者就可以直接在Word中瀏覽數據,而不用打開Excel文檔 ...


前言

在Word中創建報告時,我們經常會遇到這樣的情況:我們需要將數據從Excel中複製和粘貼到Word中,這樣讀者就可以直接在Word中瀏覽數據,而不用打開Excel文檔。在本文中,您將學習如何使用Spire.Office for Java將Excel數據轉換為Word表格並保留格式。


程式環境

安裝Spire.Office for Java

首先,你需要在你的Java程式中添加Spire.Office.jar文件作為一個依賴項。該JAR文件可以從這個鏈接下載。如果你使用Maven,你可以通過在項目的pom.xml文件中添加以下代碼,在你的應用程式中輕鬆導入該JAR文件。

點擊查看代碼
<repositories>
    <repository>
        <id>com.e-iceblue</id>
        <name>e-iceblue</name>
        <url> https://repo.e-iceblue.cn/repository/maven-public/</url>
    </repository>
</repositories>
<dependencies>
    <dependency>
        <groupId>e-iceblue</groupId>
        <artifactId>spire.office</artifactId>
        <version>7.9.6</version>
    </dependency>
</dependencies>

小tips:請註意版本號的變化

將帶格式的Excel數據導出到Word表格

步驟

創建一個Workbook對象,並使用Workbook.loadFromFile()方法載入一個Excel樣本文件。
• 使用Workbook.getWorksheets().get()方法獲取一個特定的工作表。
• 創建一個Document對象,並向其添加一個章節。
• 使用Section.addTable()方法添加一個表格。
• 檢測工作表中的合併單元格,並使用自定義方法mergeCells()合併Word tale中的相應單元格。
• 使用CellRange.getValue() 方法獲取特定Excel單元格的值,並使用TableCell.addParagraph().appendText()方法將其添加到Word表中的一個單元格。
• 使用自定義方法copyStyle()將字體樣式和單元格樣式從Excel複製到Word表格中。
• 使用Document.saveToFile()方法將文檔保存到Word文件中。

代碼示例

點擊查看代碼
import com.spire.doc.*;
import com.spire.doc.FileFormat;
import com.spire.doc.documents.HorizontalAlignment;
import com.spire.doc.documents.PageOrientation;
import com.spire.doc.documents.VerticalAlignment;
import com.spire.doc.fields.TextRange;
import com.spire.xls.*;

public class ExportExcelToWord {

    public static void main(String[] args) {

        //下載一個Excel文件
        Workbook workbook = new Workbook();
        workbook.loadFromFile("C:/Users/Administrator/Desktop/sample.xlsx");

        //得到第一張工作表
        Worksheet sheet = workbook.getWorksheets().get(0);

        //創建一個Word文檔
        Document doc = new Document();
        Section section = doc.addSection();
        section.getPageSetup().setOrientation(PageOrientation.Landscape);

        //添加一個表格
        Table table = section.addTable(true);
        table.resetCells(sheet.getLastRow(), sheet.getLastColumn());

        //合併單元格
        mergeCells(sheet, table);

        for (int r = 1; r <= sheet.getLastRow(); r++) {

            //設置行高
            table.getRows().get(r - 1).setHeight((float) sheet.getRowHeight(r));

            for (int c = 1; c <= sheet.getLastColumn(); c++) {
                CellRange xCell = sheet.getCellRange(r, c);
                TableCell wCell = table.get(r - 1, c - 1);

                //獲得特定Excel單元格的值並將其添加到Word表格單元格
                TextRange textRange = wCell.addParagraph().appendText(xCell.getValue());

                // 從Excel複製字體和單元格樣式到Word
                copyStyle(textRange, xCell, wCell);
            }
        }

        //Save the document to a Word file保存文檔為Word文件
        doc.saveToFile("ExportToWord.docx", FileFormat.Docx);
    }

    //如果有合併的區域,則合併單元格
    private static void mergeCells(Worksheet sheet, Table table) {
        if (sheet.hasMergedCells()) {

            //從Excel中獲取合併的單元格範圍
            CellRange[] ranges = sheet.getMergedCells();
            for (int i = 0; i < ranges.length; i++) {
                int startRow = ranges[i].getRow();
                int startColumn = ranges[i].getColumn();
                int rowCount = ranges[i].getRowCount();
                int columnCount = ranges[i].getColumnCount();

                //合併Word表格中的對應單元格
                if (rowCount > 1 && columnCount > 1) {
                    for (int j = startRow; j <= startRow + rowCount ; j++) {
                        table.applyHorizontalMerge(j - 1, startColumn - 1, startColumn - 1 + columnCount - 1);
                    }
                    table.applyVerticalMerge(startColumn - 1, startRow - 1, startRow - 1 + rowCount - 1 );
                }
                if (rowCount > 1 && columnCount == 1 ) {
                     table.applyVerticalMerge(startColumn - 1, startRow - 1, startRow - 1 + rowCount - 1);
                }
                if (columnCount > 1 && rowCount == 1 ) {
                    table.applyHorizontalMerge(startRow - 1, startColumn - 1,  startColumn - 1 + columnCount-1);
                }
            }
        }
    }

    //複製Excel單元格樣式到Word表格
    private static void copyStyle(TextRange wTextRange, CellRange xCell, TableCell wCell) {

        //複製字體樣式
        wTextRange.getCharacterFormat().setTextColor(xCell.getStyle().getFont().getColor());
        wTextRange.getCharacterFormat().setFontSize((float) xCell.getStyle().getFont().getSize());
        wTextRange.getCharacterFormat().setFontName(xCell.getStyle().getFont().getFontName());
        wTextRange.getCharacterFormat().setBold(xCell.getStyle().getFont().isBold());
        wTextRange.getCharacterFormat().setItalic(xCell.getStyle().getFont().isItalic());

        //複製背景色
        wCell.getCellFormat().setBackColor(xCell.getStyle().getColor());

        //複製水平對齊方式
        switch (xCell.getHorizontalAlignment()) {
            case Left:
                wTextRange.getOwnerParagraph().getFormat().setHorizontalAlignment(HorizontalAlignment.Left);
                break;
            case Center:
                wTextRange.getOwnerParagraph().getFormat().setHorizontalAlignment(HorizontalAlignment.Center);
                break;
            case Right:
                wTextRange.getOwnerParagraph().getFormat().setHorizontalAlignment(HorizontalAlignment.Right);
                break;
        }
        
        //複製垂直對齊方式
        switch (xCell.getVerticalAlignment()) {
            case Bottom:
                wCell.getCellFormat().setVerticalAlignment(VerticalAlignment.Bottom);
                break;
            case Center:
                wCell.getCellFormat().setVerticalAlignment(VerticalAlignment.Middle);
                break;
            case Top:
                wCell.getCellFormat().setVerticalAlignment(VerticalAlignment.Top);
                break;
        }
    }
}

效果圖

image

---THE END---


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 國慶假期快到了,想查查還有幾天幾小時到假期,這對程式員小菜一碟,輕輕鬆松用python寫個倒計時程式(天、時、分、秒),助你熬到假期! 一、先看效果: 二、安裝python: 1、下載安裝python 下載安裝python3.9.6,進入python官方網站://www.python.org/ 點擊 ...
  • 抽象方法和抽象類 抽象方法 使用 abstract 修飾的方法,沒有方法體,只有聲明。 定義的是一種“規範”,就是告訴子類必須要給抽象方法提供具體的實現。 抽象類 包含抽象方法的類就是抽象類。 通過抽象類,我們就可以做到嚴格限制子類的設計,使子類之間更加通用。 //抽象類的定義 public abs ...
  • 一:打開支付寶開發平臺,登錄,然後點擊控制台 https://open.alipay.com/ 二:滾動到底部,選著沙箱服務 三:獲取到對接要用的appId和公鑰私鑰 四:打開IDEA導入所需的xml文件 <!-- 支付寶--> <!-- https://mvnrepository.com/arti ...
  • 2022-09-29 shell操作: 我在使用中是pycharm與資料庫建立連接的一個工具。 使用的環境: 在此處是用在了虛擬環境中。 使用場景: 一般是在創建的表中插入數據後,進行查看,可以代替在“視圖”中——“創建一個函數用於請求指定表中的內容,在瀏覽器中返回”。 在插入表的過程中,有兩個新得 ...
  • 一、什麼是事務 事務就是一系列的業務邏輯的操作,必須要全部執行成功,否則每個操作所執行的內容都要撤銷。 二、事務的四大特性 1.原子性(atomicity):事務雖然有一系列的操作,但要把它看作一個整體(單一原子),要麼都成功,要麼都失敗; 2.一致性(consistency):事務必須是使資料庫從 ...
  • Nginx平滑升級版本 一,查看現目前版本,準備預升級版本的安裝包 #查看nginx版本 /usr/local/nginx/sbin/nginx -v #測試nginx訪問是否正常,此處開放的為19999埠 #新建下載目錄 mkdir -p /home/nginx #下載預升級版本的安裝包 wge ...
  • 在學習之前,我們先瞭解一個網站mybatis-spring,這是mybatis-spring整合的官方文檔,裡面有詳細的教程,網址如下: https://mybatis.org/spring/zh/index.html 一、什麼是mybatis-spring 以下是mybatis-spring官方給 ...
  • 2022-09-29 問題描述: 在“setting.py”的配置文件中修改資料庫引擎中,將系統預設的"sqlite3"尾碼改為了“sql”。出現問題。 原因分析: 問題查看: 修改後: 上述問題修改後,在“setting”中設置資料庫的其他內容(主機、埠、用戶、密碼、使用的指定數據名的資料庫), ...
一周排行
    -Advertisement-
    Play Games
  • 概述:在C#中,++i和i++都是自增運算符,其中++i先增加值再返回,而i++先返回值再增加。應用場景根據需求選擇,首碼適合先增後用,尾碼適合先用後增。詳細示例提供清晰的代碼演示這兩者的操作時機和實際應用。 在C#中,++i 和 i++ 都是自增運算符,但它們在操作上有細微的差異,主要體現在操作的 ...
  • 上次發佈了:Taurus.MVC 性能壓力測試(ap 壓測 和 linux 下wrk 壓測):.NET Core 版本,今天計劃準備壓測一下 .NET 版本,來測試並記錄一下 Taurus.MVC 框架在 .NET 版本的性能,以便後續持續優化改進。 為了方便對比,本文章的電腦環境和測試思路,儘量和... ...
  • .NET WebAPI作為一種構建RESTful服務的強大工具,為開發者提供了便捷的方式來定義、處理HTTP請求並返迴響應。在設計API介面時,正確地接收和解析客戶端發送的數據至關重要。.NET WebAPI提供了一系列特性,如[FromRoute]、[FromQuery]和[FromBody],用 ...
  • 原因:我之所以想做這個項目,是因為在之前查找關於C#/WPF相關資料時,我發現講解圖像濾鏡的資源非常稀缺。此外,我註意到許多現有的開源庫主要基於CPU進行圖像渲染。這種方式在處理大量圖像時,會導致CPU的渲染負擔過重。因此,我將在下文中介紹如何通過GPU渲染來有效實現圖像的各種濾鏡效果。 生成的效果 ...
  • 引言 上一章我們介紹了在xUnit單元測試中用xUnit.DependencyInject來使用依賴註入,上一章我們的Sample.Repository倉儲層有一個批量註入的介面沒有做單元測試,今天用這個示例來演示一下如何用Bogus創建模擬數據 ,和 EFCore 的種子數據生成 Bogus 的優 ...
  • 一、前言 在自己的項目中,涉及到實時心率曲線的繪製,項目上的曲線繪製,一般很難找到能直接用的第三方庫,而且有些還是定製化的功能,所以還是自己繪製比較方便。很多人一聽到自己畫就害怕,感覺很難,今天就分享一個完整的實時心率數據繪製心率曲線圖的例子;之前的博客也分享給DrawingVisual繪製曲線的方 ...
  • 如果你在自定義的 Main 方法中直接使用 App 類並啟動應用程式,但發現 App.xaml 中定義的資源沒有被正確載入,那麼問題可能在於如何正確配置 App.xaml 與你的 App 類的交互。 確保 App.xaml 文件中的 x:Class 屬性正確指向你的 App 類。這樣,當你創建 Ap ...
  • 一:背景 1. 講故事 上個月有個朋友在微信上找到我,說他們的軟體在客戶那邊隔幾天就要崩潰一次,一直都沒有找到原因,讓我幫忙看下怎麼回事,確實工控類的軟體環境複雜難搞,朋友手上有一個崩潰的dump,剛好丟給我來分析一下。 二:WinDbg分析 1. 程式為什麼會崩潰 windbg 有一個厲害之處在於 ...
  • 前言 .NET生態中有許多依賴註入容器。在大多數情況下,微軟提供的內置容器在易用性和性能方面都非常優秀。外加ASP.NET Core預設使用內置容器,使用很方便。 但是筆者在使用中一直有一個頭疼的問題:服務工廠無法提供請求的服務類型相關的信息。這在一般情況下並沒有影響,但是內置容器支持註冊開放泛型服 ...
  • 一、前言 在項目開發過程中,DataGrid是經常使用到的一個數據展示控制項,而通常表格的最後一列是作為操作列存在,比如會有編輯、刪除等功能按鈕。但WPF的原始DataGrid中,預設只支持固定左側列,這跟大家習慣性操作列放最後不符,今天就來介紹一種簡單的方式實現固定右側列。(這裡的實現方式參考的大佬 ...