解釋一下json文件(W3school)
JSON 語法是 JavaScript 語法的子集。
JSON 語法規則
JSON 語法是 JavaScript 對象表示法語法的子集。
- 數據在名稱/值對中
- 數據由逗號分隔
- 花括號保存對象
- 方括號保存數組
JSON 名稱/值對
JSON 數據的書寫格式是:名稱/值對。
名稱/值對包括字段名稱(在雙引號中),後面寫一個冒號,然後是值:
"firstName" : "John"
這很容易理解,等價於這條 JavaScript 語句:
firstName = "John"
JSON 值
JSON 值可以是:
- 數字(整數或浮點數)
- 字符串(在雙引號中)
- 邏輯值(true 或 false)
- 數組(在方括號中)
- 對象(在花括號中)
- null
JSON 對象
JSON 對象在花括號中書寫:
對象可以包含多個名稱/值對:
{ "firstName":"John" , "lastName":"Doe" }
這一點也容易理解,與這條 JavaScript 語句等價:
firstName = "John"
lastName = "Doe"
JSON 數組
JSON 數組在方括號中書寫:
數組可包含多個對象:
{
"employees": [
{ "firstName":"John" , "lastName":"Doe" },
{ "firstName":"Anna" , "lastName":"Smith" },
{ "firstName":"Peter" , "lastName":"Jones" }
]
}
在上面的例子中,對象 "employees" 是包含三個對象的數組。每個對象代表一條關於某人(有姓和名)的記錄。
JSON 使用 JavaScript 語法
因爲 JSON 使用 JavaScript 語法,所以無需額外的軟件就能處理 JavaScript 中的 JSON。
通過 JavaScript,您可以創建一個對象數組,並像這樣進行賦值:
例子
var employees = [
{ "firstName":"Bill" , "lastName":"Gates" },
{ "firstName":"George" , "lastName":"Bush" },
{ "firstName":"Thomas" , "lastName": "Carter" }
];
可以像這樣訪問 JavaScript 對象數組中的第一項:
employees[0].lastName;
返回的內容是:
Gates
可以像這樣修改數據:
employees[0].lastName = "Jobs";
在下面的章節,您將學到如何把 JSON 文本轉換爲 JavaScript 對象。
JSON 文件
- JSON 文件的文件類型是 ".json"
- JSON 文本的 MIME 類型是 "application/json"
參考鏈接:https://www.w3school.com.cn/json/json_syntax.asp
Java將excel文件轉換爲json格式
但是目前還有錯誤,還沒有解決。
需要的jar包
jar包下載地址
net.sf.json jar.zip:https://download.csdn.net/download/yql_617540298/12502605
poi-4.1.2.jar:https://download.csdn.net/download/yql_617540298/12502720
poi-3.9.jar:http://www.java2s.com/Code/Jar/p/Downloadpoi39sourcesjar.htm
poi-ooxml-4.1.2:https://downloads.apache.org/poi/release/maven/poi-ooxml/
excel格式:
excel文件路徑:G:\eclipse-workspace\test1\test.xlsx
package test1;
import java.io.File;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import net.sf.json.JSONArray;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.DateUtil;
import org.apache.poi.ss.usermodel.FormulaEvaluator;
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.ss.usermodel.WorkbookFactory;
/**
* excel表格轉成json
* @ClassName: Excel2JSONHelper
* @Description:TODO(這裏用一句話描述這個類的作用)
* @date 2017年1月6日 下午4:42:43
*/
public class Excel2JSONHelper {
//常亮,用作第一種模板類型,如下圖
private static final int HEADER_VALUE_TYPE_Z=1;
//第二種模板類型,如下圖
private static final int HEADER_VALUE_TYPE_S=2;
public static void main(String[] args) {
File dir = new File("G:\\eclipse-workspace\\test1\\test.xlsx");
Excel2JSONHelper excelHelper = getExcel2JSONHelper();
//dir文件,0代表是第一行爲保存到數據庫或者實體類的表頭,一般爲英文的字符串,2代表是第二種模板,
JSONArray jsonArray = excelHelper.readExcle(dir, 2, 2);
System.out.println(jsonArray.toString());;
}
/**
*
* 獲取一個實例
*/
private static Excel2JSONHelper getExcel2JSONHelper(){
return new Excel2JSONHelper();
}
/**
* 文件過濾
* @Title: fileNameFileter
* @Description: TODO(這裏用一句話描述這個方法的作用)
* @date 2017年1月6日 下午4:45:42
* @return: void
* @throws
*/
private boolean fileNameFileter(File file){
boolean endsWith = false;
if(file != null){
String fileName = file.getName();
endsWith = fileName.endsWith(".xls") || fileName.endsWith(".xlsx");
}
return endsWith;
}
/**
* 獲取表頭行
* @Title: getHeaderRow
* @Description: TODO(這裏用一句話描述這個方法的作用)
* @param: @param sheet
* @param: @param index
* @param: @return
* @date 2017年1月6日 下午5:05:24
* @return: Row
* @throws
*/
private Row getHeaderRow(Sheet sheet, int index){
Row headerRow = null;
if(sheet!=null){
headerRow = sheet.getRow(index);
}
return headerRow;
}
/**
* 獲取表格中單元格的value
* @Title: getCellValue
* @Description: TODO(這裏用一句話描述這個方法的作用)
* @param: @param row
* @param: @param cellIndex
* @param: @param formula
* @param: @return
* @date 2017年1月6日 下午5:40:28
* @return: Object
* @throws
*/
private Object getCellValue(Row row,int cellIndex,FormulaEvaluator formula){
Cell cell = row.getCell(cellIndex);
if(cell != null){
switch (cell.getCellType()) {
//String類型
case STRING:
return cell.getRichStringCellValue().getString();
//number類型
case NUMERIC:
if (DateUtil.isCellDateFormatted(cell)) {
return cell.getDateCellValue().getTime();
} else {
return cell.getNumericCellValue();
}
//boolean類型
case BOOLEAN:
return cell.getBooleanCellValue();
//公式
case FORMULA:
return formula.evaluate(cell).getNumberValue();
default:
return null;
}
}
return null;
}
/**
* 獲取表頭value
* @Title: getHeaderCellValue
* @Description: TODO(這裏用一句話描述這個方法的作用)
* @param: @param headerRow
* @param: @param cellIndex 英文表頭所在的行,從0開始計算哦
* @param: @param type 表頭的類型第一種 姓名(name)英文於實體類或者數據庫中的變量一致
* @param: @return
* @date 2017年1月6日 下午6:12:21
* @return: String
* @throws
*/
private String getHeaderCellValue(Row headerRow,int cellIndex,int type){
Cell cell = headerRow.getCell(cellIndex);
String headerValue = null;
if(cell != null){
//第一種模板類型
if(type == HEADER_VALUE_TYPE_Z){
headerValue = cell.getRichStringCellValue().getString();
int l_bracket = headerValue.indexOf("(");
int r_bracket = headerValue.indexOf(")");
if(l_bracket == -1){
l_bracket = headerValue.indexOf("(");
}
if(r_bracket == -1){
r_bracket = headerValue.indexOf(")");
}
headerValue = headerValue.substring(l_bracket+1, r_bracket);
}else if(type == HEADER_VALUE_TYPE_S){
//第二種模板類型
headerValue = cell.getRichStringCellValue().getString();
}
}
return headerValue;
}
/**
* 讀取excel表格
* @Title: readExcle
* @Description: TODO(這裏用一句話描述這個方法的作用)
* @param: @param file
* @param: @param headerIndex
* @param: @param headType 表頭的類型第一種 姓名(name)英文於實體類或者數據庫中的變量一致
* @return: void
* @throws
*/
public JSONArray readExcle(File file,int headerIndex,int headType){
List<Map<String, Object>> lists = new ArrayList<Map<String, Object>>();
if(!fileNameFileter(file)){
return null;
}else{
try {
//加載excel表格
WorkbookFactory wbFactory = new WorkbookFactory();
Workbook wb = wbFactory.create(file);
//讀取第一個sheet頁
Sheet sheet = wb.getSheetAt(0);
//讀取表頭行
Row headerRow = getHeaderRow(sheet, headerIndex);
//讀取數據
FormulaEvaluator formula = wb.getCreationHelper().createFormulaEvaluator();
for(int r = headerIndex+1; r<= sheet.getLastRowNum();r++){
Row dataRow = sheet.getRow(r);
Map<String, Object> map = new HashMap<String, Object>();
for(int h = 0; h<dataRow.getLastCellNum();h++){
//表頭爲key
String key = getHeaderCellValue(headerRow,h,headType);
//數據爲value
Object value = getCellValue(dataRow, h, formula);
if(!key.equals("") && !key.equals("null") && key != null ){
map.put(key, value);
}
}
lists.add(map);
}
} catch (Exception e) {
e.printStackTrace();
}
}
JSONArray jsonArray = JSONArray.fromObject(lists);
return jsonArray;
}
}
錯誤就是:
嘗試了好多方法,都沒有解決。好憂桑。
參考鏈接:https://blog.csdn.net/allen202/article/details/54145479
參考鏈接:https://blog.csdn.net/konglongaa/article/details/78510342
JAVA入門之如何通過 POI 讀取並修改 Excel
http://jingyan.baidu.com/article/fdbd4277cbaccab89e3f48a3.html
POI讀取Excel常見問題
http://www.cnblogs.com/qingxinblog/articles/3647483.html
POI操作Excel常用方法總結
http://blog.csdn.net/educast/article/details/50454810