Excel 和 JSON 都是常用的數據格式。Excel 是一種電子表格軟件,將數據存儲在單獨的單元格,可以在其上執行各種操作。JSON 是一種輕量級數據交換格式,易于閱讀和編寫,并且可以在各種編程語言中使用。在 Java 中,將 Excel 轉換為 JSON 是一種通用需求。下面我們將介紹如何在 Java 中將 Excel 轉換為 JSON。
首先,我們需要使用一些 Java 庫來讀取 Excel 文件。 Apache POI 是一個流行的 Java 庫,提供 API 以讀寫 Microsoft Office 格式文件,包括 Excel 文件。我們需要將 POI 添加到我們的項目依賴中。
<dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.17</version> </dependency>
接下來,我們需要編寫代碼來解析 Excel 文件并將其轉換為 JSON。以下是將 Excel 文件轉換為 JSON 的示例代碼:
import java.io.File; import java.io.FileInputStream; import java.io.IOException; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import com.fasterxml.jackson.databind.ObjectMapper; public class ExcelToJsonConverter { public static void main(String[] args) throws IOException { File file = new File("example.xlsx"); FileInputStream inputStream = new FileInputStream(file); Workbook workbook = new XSSFWorkbook(inputStream); Sheet sheet = workbook.getSheetAt(0); ObjectMapper mapper = new ObjectMapper(); String json = ""; for (Row row : sheet) { for (Cell cell : row) { if (cell.getColumnIndex() == 0) { json += "{"; } json += "\"" + sheet.getRow(0).getCell(cell.getColumnIndex()).getStringCellValue() + "\":\"" + cell.getStringCellValue() + "\""; if (cell.getColumnIndex() == row.getLastCellNum()-1) { json += "},"; } else { json += ","; } } } json = "[" + json.substring(0,json.length()-1) + "]"; System.out.println(json); inputStream.close(); workbook.close(); } }
在這個例子中,我們使用 FileInputStream 讀取 Excel 文件。然后,我們使用 XSSFWorkbook 類解析文件,并選擇工作表中的第一個表。接下來,我們使用 ObjectMapper 類將 Excel 數據轉換為 JSON 數據。在轉換過程中,我們首先獲取表頭信息并作為 JSON 的鍵名,然后獲取每個單元格中的數據,并將其包含在 JSON 對象中。最后,我們將所有的 JSON 對象組裝成一個數組,并輸出到控制臺中。
以上就是在 Java 中將 Excel 文件轉換為 JSON 的示例代碼和解釋。