`
zhangsibei
  • 浏览: 15720 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

java对excel的操作

 
阅读更多
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import jxl.CellType;
import jxl.DateCell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

public class ExcelUtil
{

	/**
	 * 导出复合数据到Excel (支持把map中各元素一个sheet)
	 * 
	 * @param title
	 *            各sheet中共同的标题
	 * @param colName
	 *            数据list中对应的列名,顺序与title对应。
	 * @param mutilSheetDataMap
	 *            mutilSheetDataMap中一个map元素对应一个sheet,并sheet名称为map中key
	 * @param os
	 *            输出流
	 */
	public static void exportToExcel(String[] title, String[] colName,
			Map<String, List<Map>> mutilSheetDataMap, OutputStream os)
	{
		if (title == null || title.length == 0)
		{
			throw new NullPointerException("没有定义标题集合,或者没有提供get方法");
		}
		if (colName == null || colName.length == 0)
		{
			throw new NullPointerException("没有定义字段集合,或者没有提供get方法");
		}
		if (mutilSheetDataMap == null)
		{
			throw new NullPointerException("没有定义导出数据结果集合,或者没有提供get方法");
		}
		HSSFWorkbook wwb = null;
		try
		{
			// 创建工作表
			wwb = new HSSFWorkbook();
			HSSFSheet ws = null;
			HSSFRow row = null;
			HSSFCell cell = null;
			String sheetName;
			List<Map> sheetDataList = null;
			Iterator<String> it = mutilSheetDataMap.keySet().iterator();
			while (it.hasNext())
			{
				// 按照sheet数据map的key来创建sheet
				sheetName = it.next();
				ws = wwb.createSheet(replaceStr(sheetName));
				// 获取sheet数据list
				sheetDataList = mutilSheetDataMap.get(sheetName);
				/**
				 * 写标题
				 */
				row = ws.createRow(0);
				for (int m = 0; m < title.length; m++)
				{
					cell = row.createCell((short) m);
					cell.setCellValue(new HSSFRichTextString(title[m]));
				}
				/**
				 * 写数据
				 */
				int rownum = 1;
				for (Map dataMap : sheetDataList)
				{
					row = ws.createRow(rownum);
					for (int j = 0; j < colName.length; j++)
					{
						cell = row.createCell((short) j);
						// 按字段取值
						String columnName = colName[j];
						cell.setCellValue(new HSSFRichTextString(String.valueOf(dataMap
								.get(columnName))));
					}
					rownum++;
				}
			}
			// 写入流
			wwb.write(os);
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		finally
		{
			try
			{
				os.close();
			}
			catch (IOException e)
			{
				e.printStackTrace();
			}
		}
	}

	/**
	 * 替换特殊字符串
	 * 
	 * @param str
	 * @return
	 */
	private static String replaceStr(String str)
	{
		String msg = str.replaceAll(":", "").replaceAll("/", "").replaceAll("\\?", "")
				.replaceAll("\\*", "").replaceAll("\\[", "{").replaceAll("\\]", "}");
		if (msg.length() > 31)
		{
			msg = msg.substring(0, 30);
		}
		return msg;
	}

	/**
	 * 根据传入的数组生成excel文件流,每10000行分一页 (该方法暂时不使用,保留)
	 * 
	 * @param title
	 *            表格显示的标题,默认作为每一页的第一行
	 * @param dataList
	 *            结果集数组
	 * @param os
	 *            输出流
	 */
	public static void exportToExcel(String[] title, String[][] dataList, OutputStream os)
	{
		// 然后将结果集转化为Excel输出
		// 初始化工作
		WritableWorkbook wwb = null;
		Label labelC = null;
		int k = -1;
		try
		{
			// 创建工作表
			wwb = Workbook.createWorkbook(os);
			WritableSheet ws = null;
			// 逐行添加数据
			for (int i = 0; i < dataList.length; i++)
			{
				// 每10000条记录分一页
				if (i / 10000 > k)
				{
					k = i / 10000;
					ws = wwb.createSheet("Sheet" + k, k);
					// 在每页的第一行输入标题
					for (int l = 0; l < title.length; l++)
					{
						labelC = new Label(l, 0, title[l]);
						ws.addCell(labelC);
					}
				}
				// 输出数据
				for (int j = 0; j < dataList[i].length; j++)
				{
					labelC = new Label(j, i - 10000 * k + 1, dataList[i][j]);
					ws.addCell(labelC);
				}
			}
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		finally
		{
			if (wwb != null)
			{
				try
				{
					wwb.write();
					wwb.close();
				}
				catch (Exception e)
				{
					e.printStackTrace();
				}
			}
		}
	}

	/**
	 * 输入excel文件,解析后返回ArrayList
	 * 
	 * @param file
	 *            输入的excel文件
	 * @return ArrayList<Map>,其中的map以第一行的内容为键值
	 */
	public static ArrayList<Map> importToExcel(File file)
	{
		// 初始化返回值和字段名数组
		ArrayList<Map> arr = new ArrayList<Map>();
		String[] title;
		Workbook wwb = null;
		try
		{
			// 读取excel文件
			wwb = Workbook.getWorkbook(file);
			// 总sheet数
			int sheetNumber = wwb.getNumberOfSheets();
			System.out.println("sheetNumber:" + sheetNumber);
			for (int m = 0; m < sheetNumber; m++)
			{
				Sheet ws = wwb.getSheet(m);
				// 当前页总记录行数和列数
				int rowCount = ws.getRows();
				int columeCount = ws.getColumns();
				System.out.println("rowCount:" + rowCount);
				System.out.println("columeCount:" + columeCount);
				// 第一行为字段名,所以行数大于1才执行
				if (rowCount > 1 && columeCount > 0)
				{
					// 取第一列为字段名
					title = new String[columeCount];
					for (int k = 0; k < columeCount; k++)
					{
						title[k] = ws.getCell(k, 0).getContents().trim();
					}
					// 取当前页所有值放入list中
					for (int i = 1; i < rowCount; i++)
					{
						Map dataMap = new HashMap();
						for (int j = 0; j < columeCount; j++)
						{
							if (ws.getCell(j, i).getType() == CellType.DATE)
							{
								dataMap.put(title[j], ((DateCell) ws.getCell(j, i))
										.getDate());
							}
							else
							{
								dataMap.put(title[j], ws.getCell(j, i).getContents());
							}
						}
						arr.add(dataMap);
					}
				}
			}
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		finally
		{
			if (wwb != null)
			{
				wwb.close();
				wwb = null;
			}
		}
		return arr;
	}

	/**
	 * 输入excel文件,解析后返回ArrayList
	 * 
	 * @param file
	 *            输入的excel文件
	 * @param sheetNum
	 *            数据所在的sheet页,从0开始计数
	 * @param startIndex
	 *            起始行,从0开始计数
	 * @return ArrayList<Map>,其中的map以第一行的内容为键值
	 */
	public static ArrayList<Map> importToExcel(File file, int sheetNum, int startIndex)
	{
		// 初始化返回值和字段名数组
		ArrayList<Map> arr = new ArrayList<Map>();
		String[] title;
		Workbook wwb = null;
		try
		{
			// 读取excel文件
			wwb = Workbook.getWorkbook(file);
			// 总sheet数
			int sheetNumber = wwb.getNumberOfSheets();
			System.out.println("sheetNumber:" + sheetNumber);
			// 如果指定sheet过大,直接返回空
			if (sheetNum >= sheetNumber)
			{
				return new ArrayList<Map>();
			}
			Sheet ws = wwb.getSheet(sheetNum);
			// 当前页总记录行数和列数
			int rowCount = ws.getRows();
			int columeCount = ws.getColumns();
			System.out.println("rowCount:" + rowCount);
			System.out.println("columeCount:" + columeCount);
			// 第一行为字段名,所以行数大于1才执行
			if (rowCount > (startIndex + 1) && columeCount > 0)
			{
				// 取第一列为字段名
				title = new String[columeCount];
				for (int k = 0; k < columeCount; k++)
				{
					title[k] = ws.getCell(k, startIndex).getContents().trim();
				}
				// 取当前页所有值放入list中
				for (int i = (startIndex + 1); i < rowCount; i++)
				{
					Map dataMap = new HashMap();
					for (int j = 0; j < columeCount; j++)
					{
						if (ws.getCell(j, i).getType() == CellType.DATE)
						{
							dataMap
									.put(title[j], ((DateCell) ws.getCell(j, i))
											.getDate());
						}
						else
						{
							dataMap.put(title[j], ws.getCell(j, i).getContents());
						}
					}
					arr.add(dataMap);
				}
			}
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		finally
		{
			if (wwb != null)
			{
				wwb.close();
				wwb = null;
			}
		}
		return arr;
	}

	/**
	 * 输入excel文件,解析后返回ArrayList
	 * 
	 * @param file
	 *            输入的excel文件
	 * @return ArrayList<Map>,其中的map以第一行的内容为键值,若有重复则添加数字标记
	 */
	public static ArrayList<Map> importToExcel_col(File file)
	{
		// 初始化返回值和字段名数组
		ArrayList<Map> arr = new ArrayList<Map>();
		String[] title;
		String[] tmp;
		Workbook wwb = null;
		try
		{
			// 读取excel文件
			wwb = Workbook.getWorkbook(file);
			// 总sheet数
			int sheetNumber = wwb.getNumberOfSheets();
			for (int m = 0; m < sheetNumber; m++)
			{
				Sheet ws = wwb.getSheet(m);
				// 当前页总记录行数和列数
				int rowCount = ws.getRows();
				int columeCount = ws.getColumns();
				// 第一行为字段名,所以行数大于1才执行
				if (rowCount > 1 && columeCount > 0)
				{
					// 取第一列为字段名,若有重复则增加数字做标记
					title = new String[columeCount];
					tmp = new String[columeCount];
					int count = 0;
					for (int k = 0; k < columeCount; k++)
					{
						tmp[k] = ws.getCell(k, 0).getContents();
						count = checkExit(tmp, tmp[k]);
						if (count <= 1)
						{
							title[k] = ws.getCell(k, 0).getContents().trim();
						}
						else
						{
							title[k] = ws.getCell(k, 0).getContents().trim() + "_"
									+ count;
						}
					}
					// 取当前页所有值放入list中
					for (int i = 1; i < rowCount; i++)
					{
						Map dataMap = new HashMap();
						for (int j = 0; j < columeCount; j++)
						{
							if (ws.getCell(j, i).getType() == CellType.DATE)
							{
								dataMap.put(title[j], ((DateCell) ws.getCell(j, i))
										.getDate());
							}
							else
							{
								dataMap.put(title[j], ws.getCell(j, i).getContents());
							}
						}
						arr.add(dataMap);
					}
				}
			}
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		finally
		{
			if (wwb != null)
			{
				wwb.close();
				wwb = null;
			}
		}
		return arr;
	}

	/**
	 * 根据传入的数组生成excel文件流,每10000行分一页 (使用poi方法)
	 * 
	 * @param title
	 *            表格显示的标题,默认作为每一页的第一行
	 * @param dataList
	 *            结果集数组
	 * @param os
	 *            输出流
	 */
	public static void exportToExcel_poi(String[] title, String[][] dataList,
			OutputStream os)
	{
		// 将结果集转化为Excel输出
		int k = -1;
		HSSFWorkbook wwb = null;
		try
		{
			// 创建工作表
			wwb = new HSSFWorkbook();
			HSSFSheet ws = null;
			HSSFRow row = null;
			HSSFCell cell = null;
			// 逐行添加数据
			for (int i = 0; i < dataList.length; i++)
			{
				// 每10000条记录分一页
				if (i / 10000 > k)
				{
					k = i / 10000;
					ws = wwb.createSheet("Sheet" + k);
					row = ws.createRow(0);
					// 在每页的第一行输入标题
					for (int l = 0; l < title.length; l++)
					{
						cell = row.createCell((short) l);
						cell.setCellValue(new HSSFRichTextString(title[l]));
					}
				}
				// 输出数据
				for (int j = 0; j < dataList[i].length; j++)
				{
					row = ws.createRow(i - 10000 * k + 1);
					cell = row.createCell((short) j);
					cell.setCellValue(new HSSFRichTextString(dataList[i][j]));
				}
			}
			wwb.write(os);
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		finally
		{
			try
			{
				os.close();
			}
			catch (Exception e)
			{
				e.printStackTrace();
			}
		}
	}

	/**
	 * 传入excel文件,解析后返回ArrayList
	 * 
	 * @param file
	 * @param startIndex
	 *            从第几行开始解析
	 */
	public static ArrayList<ArrayList> importExcel_poi(File file, int startIndex)
	{
		ArrayList<ArrayList> arr = new ArrayList<ArrayList>();
		// 初始化
		FileInputStream readFile = null;
		HSSFWorkbook wb = null;
		HSSFRow row = null;
		HSSFCell cell = null;
		try
		{
			// 读取文件
			readFile = new FileInputStream(file);
			wb = new HSSFWorkbook(readFile);
			// 文档的页数
			int numOfSheets = wb.getNumberOfSheets();
			System.out.println("numOfSheets:" + numOfSheets);
			for (int k = 0; k < numOfSheets; k++)
			{
				// 获取当前的
				HSSFSheet st = wb.getSheetAt(k);
				// 当前页的行数
				int rows = st.getLastRowNum();
				// 分行解析
				for (int i = startIndex; i <= rows; i++)
				{
					// 行为空则执行下一行
					if (st.getRow(i) == null)
					{
						continue;
					}
					row = st.getRow(i);
					int cells = row.getLastCellNum();
					ArrayList<String> data = new ArrayList<String>();
					// 分列
					for (int j = 0; j < cells; j++)
					{
						// 列为空则输入空字符串
						if (row.getCell((short) j) == null)
						{
							data.add("");
							continue;
						}
						cell = row.getCell((short) j);
						// 对字段分类处理
						switch (cell.getCellType())
						{
							case HSSFCell.CELL_TYPE_NUMERIC:
							{
								Integer num = new Integer((int) cell
										.getNumericCellValue());
								data.add(String.valueOf(num));
								break;
							}
							case HSSFCell.CELL_TYPE_STRING:
							{
								data.add(cell.getRichStringCellValue().toString());
								break;
							}
							default:
								data.add("");
						}
					}
					arr.add(data);
				}
			}
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		finally
		{
			try
			{
				readFile.close();
			}
			catch (Exception e)
			{
				e.printStackTrace();
			}
		}
		return arr;
	}

	/**
	 * 传入excel文件,解析后返回ArrayList。文件的第一行表示字段的名称
	 * 
	 * @param file
	 */
	public static ArrayList<Map> importExcel_poi(File file)
	{
		ArrayList<Map> arr = new ArrayList<Map>();
		String[] title;
		// 初始化
		FileInputStream readFile = null;
		HSSFWorkbook wb = null;
		HSSFRow row = null;
		HSSFSheet st = null;
		HSSFCell cell = null;
		try
		{
			// 读取文件
			readFile = new FileInputStream(file);
			wb = new HSSFWorkbook(readFile);
			// 文档的页数
			int numOfSheets = wb.getNumberOfSheets();
			System.out.println("numOfSheets:" + numOfSheets);
			for (int k = 0; k < numOfSheets; k++)
			{
				// 获取当前的
				st = wb.getSheetAt(k);
				// 当前页的行数
				int rows = st.getLastRowNum();
				// 如果行数大于0,则先取第一行为字段名
				if (rows > 0)
				{
					row = st.getRow(0);
					int cells = row.getLastCellNum();
					title = new String[cells];
					for (int j = 0; j < cells; j++)
					{
						// 列为空则输入空字符串
						if (row.getCell((short) j) == null)
						{
							title[j] = "";
							continue;
						}
						cell = row.getCell((short) j);
						switch (cell.getCellType())
						{
							case HSSFCell.CELL_TYPE_NUMERIC:
							{
								Integer num = new Integer((int) cell
										.getNumericCellValue());
								title[j] = String.valueOf(num);
								break;
							}
							case HSSFCell.CELL_TYPE_STRING:
							{
								title[j] = cell.getRichStringCellValue().toString();
								break;
							}
							default:
								title[j] = "";
						}
					}
					// 分行解析
					for (int i = 1; i <= rows; i++)
					{
						// 行为空则执行下一行
						if (st.getRow(i) == null)
						{
							continue;
						}
						// 将每行数据放入map中
						row = st.getRow(i);
						arr.add(getCellMap(row, cells, title));
					}
				}
			}
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		finally
		{
			try
			{
				readFile.close();
			}
			catch (Exception e)
			{
				e.printStackTrace();
			}
		}
		return arr;
	}

	/**
	 * 将数据写入EXCEL文件的指定位置
	 * 
	 * @param file
	 *            EXCEL文件
	 * @param data
	 *            需要写入的数据,二维表格的数据
	 * @param sheetNum
	 *            sheet序号,从0开始计数
	 * @param startRow
	 *            其实行,从0开始计数
	 * @param startCol
	 *            其实列,从0开始计数
	 * @return 修改完成的EXCEL
	 */
	public static File insertExcelContent(File file, List<List<String>> data,
			int sheetNum, int startRow, int startCol)
	{
		if (null == data || data.size() == 0)
		{
			System.err.println("[insertExcelContent]data is null");
			return file;
		}
		System.out.println("[insertExcelContent]data:" + data);
		WritableWorkbook wwb = null;
		Label labelC = null;
		try
		{
			// 读取excel文件
			Workbook book = Workbook.getWorkbook(file);
			// 打开这个文件的副本,并且指定数据写回到原文件
			wwb = Workbook.createWorkbook(file, book);
			// 总sheet数
			int sheetNumber = wwb.getNumberOfSheets();
			System.out.println("sheetNumber:" + sheetNumber);
			// 如果指定sheet过大,直接原文件
			if (sheetNum >= sheetNumber)
			{
				return file;
			}
			WritableSheet ws = wwb.getSheet(sheetNum);
			// 写文件
			int i = startRow;
			int j = startCol;
			for (List<String> rowData : data)
			{
				for (String cellData : rowData)
				{
					labelC = new Label(j, i, cellData, ws.getCell(j, i).getCellFormat());
					System.out.println("startRow:" + i + ",startCol:" + j + ",value:"
							+ cellData);
					try
					{
						ws.addCell(labelC);
					}
					catch (NullPointerException e)
					{
						labelC = new Label(j, i, cellData);
						ws.addCell(labelC);
					}
					j++;
				}
				i++;
				j = startCol;
			}
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		finally
		{
			if (wwb != null)
			{
				try
				{
					wwb.write();
					wwb.close();
					wwb = null;
				}
				catch (Exception e)
				{
					e.printStackTrace();
				}
			}
		}
		return file;
	}

	/**
	 * 根据传入的excel行数据得到数据Map
	 * 
	 * @param row
	 * @param cells
	 * @param title
	 * @return
	 */
	private static Map getCellMap(HSSFRow row, int cells, String[] title)
	{
		// 初始化
		HSSFCell cell = null;
		Map<String, String> data = new HashMap<String, String>();
		// 分列
		for (int j = 0; j < cells; j++)
		{
			// 列为空则输入空字符串
			if (row.getCell((short) j) == null)
			{
				data.put(title[j], "");
				continue;
			}
			cell = row.getCell((short) j);
			// 对字段分类处理
			switch (cell.getCellType())
			{
				case HSSFCell.CELL_TYPE_NUMERIC:
				{
					Integer num = new Integer((int) cell.getNumericCellValue());
					data.put(title[j], String.valueOf(num));
					break;
				}
				case HSSFCell.CELL_TYPE_STRING:
				{
					data.put(title[j], cell.getRichStringCellValue().toString());
					break;
				}
				default:
					data.put(title[j], "");
			}
		}
		return data;
	}

	/**
	 * 返回数组中有几个重复纪录
	 * 
	 * @param arr
	 * @param value
	 * @return
	 */
	private static int checkExit(String[] arr, String value)
	{
		int j = 0;
		for (int i = 0; i < arr.length; i++)
		{
			if (arr[i] != null && value.equals(arr[i]))
			{
				j++;
			}
		}
		return j;
	}

	/**
	 * 导出复合数据到Excel (支持把map中各元素一个sheet)
	 * 
	 * @param title
	 *            各sheet中各个对应的标题
	 * @param colName
	 *            数据list中对应的列名,顺序与title对应。
	 * @param mutilSheetDataMap
	 *            mutilSheetDataMap中一个map元素对应一个sheet,并sheet名称为map中key
	 * @param os
	 *            输出流
	 */
	public static void exportToExcel2(List<String[]> title, List<String[]> colName,
			Map<String, List<Map>> mutilSheetDataMap, OutputStream os)
	{
		if (title == null || title.size() == 0)
		{
			throw new NullPointerException("没有定义标题集合,或者没有提供get方法");
		}
		if (colName == null || colName.size() == 0)
		{
			throw new NullPointerException("没有定义字段集合,或者没有提供get方法");
		}
		if (mutilSheetDataMap == null)
		{
			throw new NullPointerException("没有定义导出数据结果集合,或者没有提供get方法");
		}
		HSSFWorkbook wwb = null;
		try
		{
			// 创建工作表
			wwb = new HSSFWorkbook();
			HSSFSheet ws = null;
			HSSFRow row = null;
			HSSFCell cell = null;
			String sheetName;
			List<Map> sheetDataList = null;
			Iterator<String> it = mutilSheetDataMap.keySet().iterator();
			Iterator<String[]> titleIt = title.iterator();
			String[] titleArr = null;
			Iterator<String[]> colNameIt = colName.iterator();
			String[] colNameArr = null;
			while (it.hasNext())
			{
				// 按照sheet数据map的key来创建sheet
				sheetName = it.next();
				ws = wwb.createSheet(replaceStr(sheetName));
				// 获取sheet数据list
				sheetDataList = mutilSheetDataMap.get(sheetName);
				/**
				 * 写标题
				 */
				row = ws.createRow(0);
				titleArr = titleIt.next();
				for (int m = 0; m < titleArr.length; m++)
				{
					cell = row.createCell((short) m);
					cell.setCellValue(new HSSFRichTextString(titleArr[m]));
				}
				/**
				 * 写数据
				 */
				int rownum = 1;
				colNameArr = colNameIt.next();
				for (Map dataMap : sheetDataList)
				{
					row = ws.createRow(rownum);
					for (int j = 0; j < colNameArr.length; j++)
					{
						cell = row.createCell((short) j);
						// 按字段取值
						String columnName = colNameArr[j];
						cell.setCellValue(new HSSFRichTextString(String.valueOf(dataMap
								.get(columnName))));
					}
					rownum++;
				}
			}
			// 写入流
			wwb.write(os);
		}
		catch (Exception e)
		{
			e.printStackTrace();
		}
		finally
		{
			try
			{
				os.close();
			}
			catch (IOException e)
			{
				e.printStackTrace();
			}
		}
	}
}

 另外如果是要下载excel魔板时,定义输入流

private InputStream exportExcelStream;

 get,set 方法

	public InputStream getExportExcelStream()
	{
		FileInputStream fio = null;
		String path = ServletActionContext.getServletContext().getRealPath("/");
		String separa = System.getProperty("file.separator");
		String filePath = path + "aaa" + separa + "bbb" + separa
				+ "batchImport.xls";
		try
		{
			fio = new FileInputStream(filePath);
		}
		catch (FileNotFoundException e)
		{
			logger.warn("读取文件异常", e);
		}
		return fio;
	}

	public void setExportExcelStream(InputStream exportExcelStream)
	{
		this.exportExcelStream = exportExcelStream;
	}

 struts.xml配置文件

<result name="export" type="stream">
				<param name="contentType">application/vnd.ms-excel</param>
				<param name="contentDisposition">attachment;filename="batchImport.xls"</param>
				<param name="inputName">exportExcelStream</param>
			</result>

 

分享到:
评论

相关推荐

    java对excel操作

    以上是使用Java和Apache POI进行Excel操作的基本知识点,通过这些知识,你可以实现从Excel文件读取数据并将其导入到MySQL数据库中。在实际项目中,根据具体需求,可能还需要涉及更复杂的功能,如数据验证、图表操作...

    java对excel操作所用的jar包.rar

    "java对excel操作所用的jar包.rar" 提供的正是这样一组库,使得在Java中与Excel交互变得简单。这里我们将详细讨论如何使用这些jar包以及相关的知识点。 首先,Java中处理Excel最常用的库是Apache POI。Apache POI是...

    JAVA对Excel操作

    通过以上介绍,你应能使用Java有效地进行Excel操作。无论你是要创建新的工作簿、读取现有数据还是更新内容,都有相应的工具和方法可以帮助你实现。记得在实际应用中根据项目需求选择最适合的库和策略。

    java对Excel的操作

    Java提供了多种库来支持对Excel的读写操作,使得开发者能够方便地进行Excel文件的处理。本篇文章将深入探讨Java对Excel的操作。 首先,我们最常使用的Java库是Apache POI。Apache POI是一个开源项目,它提供了API来...

    Java 操作Excel和Word的所有资料

    Java 操作Excel和Word的所有资料Java 操作Excel和Word的所有资料Java 操作Excel和Word的所有资料Java 操作Excel和Word的所有资料Java 操作Excel和Word的所有资料Java 操作Excel和Word的所有资料Java 操作Excel和Word...

    java 对excel文件操作

    本知识点将详细介绍如何使用Java进行Excel文件操作,包括读取和写入,以及涉及的工作表管理。 首先,Java处理Excel文件主要依赖于Apache POI库。Apache POI是一个开源项目,它提供了Java API来处理Microsoft Office...

    jxl.jar(JAVA对EXCEL表格的操作)

    **描述分析:**"java的jar包,jxl.jar ,支持JAVA对EXCEL操作的类库。官网下载可能比较慢,或者根本无法下载,在此提供方便下载。" 这段描述指出`jxl.jar`是一个专为Java设计的库,用于处理Excel相关的任务。由于...

    jxl Java操作Excel

    java操作Excel java操作Excel java操作Excel

    Java操作Excel表格

    当我们谈论“Java操作Excel表格”时,通常是指使用Java来读取、写入或处理Microsoft Excel文件,这在数据分析、报表生成或者数据交换等场景中非常常见。本主题将围绕Java如何与Excel交互进行深入探讨。 首先,Java...

    Java对Excel表格的操作

    ### Java对Excel表格的操作 #### 1. JSP与Excel的交互 在现代软件开发中,尤其是基于B/S(浏览器/服务器)架构的应用程序,处理客户端报表和其他文档的需求变得日益重要。由于B/S架构的限制,如缺乏丰富的客户端...

    Java对Excel表格的操作.doc

    Java对Excel表格的操作主要涉及到B/S架构下的Web报表处理,由于Java标准库中并不包含直接操作Excel的API,因此开发者通常需要借助第三方库来完成这项任务。本文档着重介绍了两个常用的开源工具:Apache POI和...

    java对excel的添加,java对excel的查询

    本主题将深入探讨如何使用Java对Excel进行添加数据和查询数据的操作。以下四个类,每个都专注于一个特定的方法: 1. **ExcelWriter.java**: 这个类通常用于写入数据到Excel文件。在Java中,可以使用Apache POI库...

    java对excel进行操作

    在Java编程环境中,对Excel文件进行操作是一项常见的需求,尤其在数据处理、报表生成或数据分析等领域。本项目利用Java的库和javabeans技术来实现对Excel文件的读写、修改和增删行列等操作。以下将详细阐述相关知识...

    java生成excel图表

    "Java生成Excel图表" Java生成Excel图表是使用Java语言来生成Excel图表的过程。Excel图表是指使用Excel软件生成的图表,例如柱状图、折线图、饼状图等。Java语言可以使用各种库和框架来生成Excel图表,例如...

    Java操作Excel详解

    ### Java操作Excel详解 #### 一、Java Excel API简介 Java Excel API是一个强大的开源库,允许开发者使用Java语言轻松地创建、更新以及读取Excel文件。这个库支持多种Excel文件格式,包括较旧版本(如.xls)和较新...

    java 操作excel表格经典例子

    ### Java操作Excel表格经典案例分析 #### 一、引言 在日常办公环境中,Microsoft Office套件中的Excel因其强大的数据处理能力而被广泛使用。在Java编程领域,开发者经常需要处理Excel文件,如批量导入导出数据、...

    java操作excel,函数计算

    java是不能提供java调用excel里的函数的,所以我提供这个例子,让大家参考,必须导入jxl.jar包哦!

    利用JAVA操作EXCEL文件.pdf

    综上所述,JavaExcelAPI为Java开发者提供了一个强大的工具箱,极大地简化了对Excel文件的操作流程,无论是简单的数据读取还是复杂的报表生成,都能轻松应对。随着项目不断发展和完善,其应用范围还将进一步扩大。

    java操作excel实现水印图片

    java操作excel实现水印图片

Global site tag (gtag.js) - Google Analytics