- 浏览: 237934 次
- 性别:
- 来自: 上海
博客专栏
-
Java应用集锦
浏览量:22944
文章分类
最新评论
-
yipeng_666:
yipeng_666 写道楼主可以分享源码吗 , 感激不尽邮 ...
基于jquery框架dwz做的后台管理系统 -
yipeng_666:
楼主可以分享源码吗 , 感激不尽
基于jquery框架dwz做的后台管理系统 -
ughome:
楼主,能发个源码吗,我删除后刷新有问题,总是跳转到第一页。查询 ...
基于jquery框架dwz做的后台管理系统 -
ellie_it:
DWZ研究中,楼主可以分享源码学习下吗?万分感谢! 93020 ...
基于jquery框架dwz做的后台管理系统 -
hongshenghome:
前辈,dwz刚开始学,给我发份源码,万分感谢!!!!!,邮箱 ...
基于jquery框架dwz做的后台管理系统
转载请注明出处: http://renjie120.iteye.com/
最近项目开发中对excel操作比较频繁,并结合正则表达式进行了一些处理,整理一下.
1.正则表达式常用方法
/** * 在第一个字符串中查找匹配字符串的个数 * @param str * @param regexStr * @return */ public static int count(String str,String regexStr){ int count = 0; Pattern pt = Pattern.compile(regexStr); Matcher m = pt.matcher(str); int start = 0; while(m.find()){ count++; } return count; } /** * 根据正则表达式分割str字符串成为一个一个的小的单元! * (实际使用:在一个类似语法分析的模块中发挥重要作用) * 例如:3+5*4 根据正则表达式+-\* 分割成数组 3,+,5,*,4 * @param str * @param regexStr * @return */ public static List splitByStr(String str,String regexStr){ List temp = new ArrayList(); Pattern pt = Pattern.compile(regexStr); Matcher m = pt.matcher(str); int start = 0; while(m.find()){ //去掉下面的字符串中为空串的情况! if(m.start()!=start) temp.add(str.substring(start, m.start())); temp.add(str.substring(m.start(),m.end())); start = m.end(); } temp.add(str.substring(start)); return temp; } /** * 检查是否含有指定的正则表达式匹配的子串. * @param str 目标字符串 * @param regex 正则表达式,如果正则表达式含有"^......$"就是查找整个字符串对象是否符合正则表达式. * @return */ public static boolean checkInclude(String str,String regex){ Pattern pattern = Pattern.compile(regex); Matcher matcher = null; matcher = pattern.matcher(str); return matcher.find(); } /** * 方法字符串中符合正则表达式的子串的集合. * @param str * @param regex * @return */ public static List getRightSubStr(String str, String regex) { List ans = new ArrayList(); Pattern pattern = Pattern.compile(regex); Matcher matcher = pattern.matcher(str); while (matcher.find()) { //注意要下面的goup()函数中可以含有数字,表示查找得到正则表达式中的goup匹配串. ans.add(matcher.group()); System.out.println("找到匹配的字符串 \"" + matcher.group() + "\" 开始于 " + matcher.start() + " 结束于 " + matcher.end() + "."); } return ans; }
下面是java正则表达式经常使用的一些方法和说明:
(1)使用matches方法快速建设是否表示给定的输入字符串:Pattern.matches("\\d","1")返回true (2)split(string)使用方法:Pattern.compile(":").split("one:two:three:four:five"); 返回:解析出“one two three four five”单词 再比如使用数字作为一个分割字符串的方法:(注意下面的\\d不是正则表达式,而是前面加了一个转义符号\) Pattern.compile("\\d").split("one9two4three7four1five");也返回相同的结果。。 (3)在String类中有的几个与Pattern类似的方法: public boolean matches(String regex): public String[] split(String regex, int limit): public String[] split(String regex): public String replace(CharSequence target,CharSequence replacement): (4) Matcher 类中其他一些有用的方法 索引方法 索引方法(index methods)提供了一些正好在输入字符串中发现匹配的索引值: public int start():返回之前匹配的开始索引。 public int start(int group):返回之前匹配操作中通过给定组所捕获序列的开始索引。 public int end(): 返回最后匹配字符后的偏移量。 public int end(int group): 返回之前匹配操作中通过给定组所捕获序列的最后字符之后的偏移量。 研究方法 研究方法(study methods)回顾输入的字符串,并且返回一个用于指示是否找到模式的布尔值。 public boolean lookingAt(): 尝试从区域开头处开始,输入序列与该模式匹配。 public boolean find(): 尝试地寻找输入序列中,匹配模式的下一个子序列。 public boolean find(int start): 重置匹配器,然后从指定的索引处开始,尝试地寻找输入序列中,匹配模式的下一个子序列。 public boolean matches(): 尝试将整个区域与模式进行匹配 替换方法 替换方法(replacement methods)用于在输入的字符串中替换文本有用处的方法。 public Matcher appendReplacement(StringBuffer sb, String replacement):实现非结尾处的增加和替换操作。 public StringBuffer appendTail(StringBuffer sb):实现结尾处的增加和替换操作。 public String replaceAll(String replacement):使用给定的替换字符串来替换输入序列中匹配模式的每一个子序列。 public String replaceFirst(String replacement):使用给定的替换字符串来替换输入序列中匹配模式的第一个子序列。 public static String quoteReplacement(String s):返回指定字符串的字面值来替换字符串。这个方法会生成一个字符串,用作 Matcher 的 appendReplacement 方法中的字面值替换 s。所产生的字符串将与作为字面值序列的 s 中的字符序列匹配。斜线(\)和美元符号($)将不再有特殊意义了。
正则表达式基础:
字符类
预定义字符类
边界匹配器 |
2.使用jxl进行exlce的基本操作
下面基础代码来自于网络:
import java.io.File; import java.io.FileOutputStream; import java.io.OutputStream; import java.util.ArrayList; import java.util.Date; import jxl.Cell; import jxl.CellType; import jxl.Sheet; import jxl.Workbook; import jxl.WorkbookSettings; import jxl.format.Alignment; import jxl.format.Border; import jxl.format.BorderLineStyle; import jxl.format.Colour; import jxl.format.VerticalAlignment; import jxl.write.Formula; import jxl.write.Label; import jxl.write.NumberFormat; import jxl.write.WritableCellFeatures; import jxl.write.WritableCellFormat; import jxl.write.WritableFont; import jxl.write.WritableSheet; import jxl.write.WritableWorkbook; import jxl.write.WriteException; public class JExcelUtils { /** * 生成Excel文件 * @param path 文件路径 * @param sheetName 工作表名称 * @param dataTitles 数据标题 */ public void createExcelFile(String path,String sheetName,String[] dataTitles){ WritableWorkbook workbook; try{ OutputStream os=new FileOutputStream(path); workbook=Workbook.createWorkbook(os); WritableSheet sheet = workbook.createSheet(sheetName, 0); //添加第一个工作表 initialSheetSetting(sheet); Label label; for (int i=0; i<dataTitles.length; i++){ //Label(列号,行号,内容,风格) label = new Label(i, 0, dataTitles[i],getTitleCellFormat()); sheet.addCell(label); } //插入一行 insertRowData(sheet,1,new String[]{"200201001","张三","100","60","100","260"},getDataCellFormat(CellType.STRING_FORMULA)); //一个一个插入行 label = new Label(0, 2,"200201002",getDataCellFormat(CellType.STRING_FORMULA)); sheet.addCell(label); label = new Label(1, 2,"李四",getDataCellFormat(CellType.STRING_FORMULA)); sheet.addCell(label); insertOneCellData(sheet,2,2,70.5,getDataCellFormat(CellType.NUMBER)); insertOneCellData(sheet,3,2,90.523,getDataCellFormat(CellType.NUMBER)); insertOneCellData(sheet,4,2,60.5,getDataCellFormat(CellType.NUMBER)); insertFormula(sheet,5,2,"C3+D3+E3",getDataCellFormat(CellType.NUMBER_FORMULA)); //插入日期 mergeCellsAndInsertData(sheet, 0, 3, 5, 3, new Date(), getDataCellFormat(CellType.DATE)); workbook.write(); workbook.close(); }catch(Exception e){ e.printStackTrace(); } } /** * 初始化表格属性 * @param sheet */ public void initialSheetSetting(WritableSheet sheet){ try{ //sheet.getSettings().setProtected(true); //设置xls的保护,单元格为只读的 sheet.getSettings().setDefaultColumnWidth(10); //设置列的默认宽度 //sheet.setRowView(2,false);//行高自动扩展 //setRowView(int row, int height);--行高 //setColumnView(int col,int width); --列宽 sheet.setColumnView(0,20);//设置第一列宽度 }catch(Exception e){ e.printStackTrace(); } } /** * 插入公式 * @param sheet * @param col * @param row * @param formula * @param format */ public void insertFormula(WritableSheet sheet,Integer col,Integer row,String formula,WritableCellFormat format){ try{ Formula f = new Formula(col, row, formula, format); sheet.addCell(f); }catch(Exception e){ e.printStackTrace(); } } /** * 插入一行数据 * @param sheet 工作表 * @param row 行号 * @param content 内容 * @param format 风格 */ public void insertRowData(WritableSheet sheet,Integer row,String[] dataArr,WritableCellFormat format){ try{ Label label; for(int i=0;i<dataArr.length;i++){ label = new Label(i,row,dataArr[i],format); sheet.addCell(label); } }catch(Exception e){ e.printStackTrace(); } } /** * 插入单元格数据 * @param sheet * @param col * @param row * @param data */ public void insertOneCellData(WritableSheet sheet,Integer col,Integer row,Object data,WritableCellFormat format){ try{ if(data instanceof Double){ jxl.write.Number labelNF = new jxl.write.Number(col,row,(Double)data,format); sheet.addCell(labelNF); }else if(data instanceof Boolean){ jxl.write.Boolean labelB = new jxl.write.Boolean(col,row,(Boolean)data,format); sheet.addCell(labelB); }else if(data instanceof Date){ jxl.write.DateTime labelDT = new jxl.write.DateTime(col,row,(Date)data,format); sheet.addCell(labelDT); setCellComments(labelDT, "这是个创建表的日期说明!"); }else{ Label label = new Label(col,row,data.toString(),format); sheet.addCell(label); } }catch(Exception e){ e.printStackTrace(); } } /** * 合并单元格,并插入数据 * @param sheet * @param col_start * @param row_start * @param col_end * @param row_end * @param data * @param format */ public void mergeCellsAndInsertData(WritableSheet sheet,Integer col_start,Integer row_start,Integer col_end,Integer row_end,Object data, WritableCellFormat format){ try{ sheet.mergeCells(col_start,row_start,col_end,row_end);// 左上角到右下角 insertOneCellData(sheet, col_start, row_start, data, format); }catch(Exception e){ e.printStackTrace(); } } /** * 给单元格加注释 * @param label * @param comments */ public void setCellComments(Object label,String comments){ WritableCellFeatures cellFeatures = new WritableCellFeatures(); cellFeatures.setComment(comments); if(label instanceof jxl.write.Number){ jxl.write.Number num = (jxl.write.Number)label; num.setCellFeatures(cellFeatures); }else if(label instanceof jxl.write.Boolean){ jxl.write.Boolean bool = (jxl.write.Boolean)label; bool.setCellFeatures(cellFeatures); }else if(label instanceof jxl.write.DateTime){ jxl.write.DateTime dt = (jxl.write.DateTime)label; dt.setCellFeatures(cellFeatures); }else{ Label _label = (Label)label; _label.setCellFeatures(cellFeatures); } } /** * 读取excel * @param inputFile * @param inputFileSheetIndex * @throws Exception */ public ArrayList<String> readDataFromExcel(File inputFile, int inputFileSheetIndex){ ArrayList<String> list = new ArrayList<String>(); Workbook book = null; Cell cell = null; WorkbookSettings setting = new WorkbookSettings(); java.util.Locale locale = new java.util.Locale("zh","CN"); setting.setLocale(locale); setting.setEncoding("ISO-8859-1"); try{ book = Workbook.getWorkbook(inputFile, setting); }catch(Exception e){ e.printStackTrace(); } Sheet sheet = book.getSheet(inputFileSheetIndex); for (int rowIndex = 0; rowIndex < sheet.getRows(); rowIndex++) {//行 for (int colIndex = 0; colIndex < sheet.getColumns(); colIndex++) {//列 cell = sheet.getCell(colIndex, rowIndex); //System.out.println(cell.getContents()); list.add(cell.getContents()); } } book.close(); return list; } /** * 得到数据表头格式 * @return */ public WritableCellFormat getTitleCellFormat(){ WritableCellFormat wcf = null; try { //字体样式 WritableFont wf = new WritableFont(WritableFont.TIMES,12, WritableFont.NO_BOLD,false);//最后一个为是否italic wf.setColour(Colour.RED); wcf = new WritableCellFormat(wf); //对齐方式 wcf.setAlignment(Alignment.CENTRE); wcf.setVerticalAlignment(VerticalAlignment.CENTRE); //边框 wcf.setBorder(Border.ALL,BorderLineStyle.THIN); //背景色 wcf.setBackground(Colour.GREY_25_PERCENT); } catch (WriteException e) { e.printStackTrace(); } return wcf; } /** * 得到数据格式 * @return */ public WritableCellFormat getDataCellFormat(CellType type){ WritableCellFormat wcf = null; try { //字体样式 if(type == CellType.NUMBER || type == CellType.NUMBER_FORMULA){//数字 NumberFormat nf = new NumberFormat("#.00"); wcf = new WritableCellFormat(nf); }else if(type == CellType.DATE || type == CellType.DATE_FORMULA){//日期 jxl.write.DateFormat df = new jxl.write.DateFormat("yyyy-MM-dd hh:mm:ss"); wcf = new jxl.write.WritableCellFormat(df); }else{ WritableFont wf = new WritableFont(WritableFont.TIMES,10, WritableFont.NO_BOLD,false);//最后一个为是否italic wcf = new WritableCellFormat(wf); } //对齐方式 wcf.setAlignment(Alignment.CENTRE); wcf.setVerticalAlignment(VerticalAlignment.CENTRE); //边框 wcf.setBorder(Border.LEFT,BorderLineStyle.THIN); wcf.setBorder(Border.BOTTOM,BorderLineStyle.THIN); wcf.setBorder(Border.RIGHT,BorderLineStyle.THIN); //背景色 wcf.setBackground(Colour.WHITE); wcf.setWrap(true);//自动换行 } catch (WriteException e) { e.printStackTrace(); } return wcf; } /** * 打开文件看看 * @param exePath * @param filePath */ public void openExcel(String exePath,String filePath){ Runtime r=Runtime.getRuntime(); String cmd[]={exePath,filePath}; try{ r.exec(cmd); }catch(Exception e){ e.printStackTrace(); } } public static void main(String[] args){ String[] titles = {"学号","姓名","语文","数学","英语","总分"}; JExcelUtils jxl = new JExcelUtils(); String filePath = "E:/test.xls"; jxl.createExcelFile(filePath," 成绩单",titles); jxl.readDataFromExcel(new File(filePath),0); jxl.openExcel("C:/Program Files/Microsoft Office/OFFICE11/EXCEL.EXE",filePath); } }
3.下面含有几个十分有用针对excel操作的的工具方法:
import java.io.File; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.regex.Matcher; import java.util.regex.Pattern; import jxl.Cell; import jxl.CellView; import jxl.Sheet; import jxl.SheetSettings; import jxl.Workbook; import jxl.format.Alignment; import jxl.write.Label; import jxl.write.WritableFont; import jxl.write.WritableSheet; import jxl.write.WritableWorkbook; /** * jxl操作excel的工具类. * */ public class JxlTool { public static int count = 1; //存储带有级别信息的内容到位置的映射关系. private static Map levelToLocation = new HashMap(); public static void readExcel(String fileName) { Workbook wb = null; try { wb = Workbook.getWorkbook(new File(fileName)); Sheet[] sheets = wb.getSheets(); for(int i=0;i<sheets.length;i++){ Sheet ii = sheets[i]; System.out.println("第"+i+"个sheet的名字是"+ii.getName()); } } catch (Exception e) { System.out.println("出现异常" + e); e.printStackTrace(); } finally { wb.close(); } } private static String allChar = "abcdefghijklmnopqrstuvwxyz"; /** * 从字符中得到列数.例如K-->10,A-->0,AA-->27 * @return */ public static int getNumFromExcelStr(String code) { int result = 0; code = code.toLowerCase(); if(code.length()>1){ char[] c = code.toCharArray(); int len = c.length; for(int i=0;i<len;i++){ if(i<len-1){ result+=(allChar.indexOf(c[i])+1)*26; }else{ result+=allChar.indexOf(c[i])+1; } } result-=1; } else return allChar.indexOf(code); return result; } /** * 根据行号和列号得到所在的单元格.例如(3,4)-->"E4" * @param vNum 纵坐标 * @param hNum 横坐标 * @return */ public static String getCellInfo(int hNum,int vNum){ char[] cs = allChar.toCharArray(); String hStr = ""; if(vNum>25){ hStr = String.valueOf(cs[vNum/26-1])+String.valueOf(cs[vNum%26-1]); }else{ hStr = String.valueOf(cs[vNum]); } return (hStr+Integer.toString((hNum+1))).toUpperCase(); } /** * 得到一个字符串里面的字符.A12-->A * @param oldStr * @return */ public static String getCodeFromStr(String oldStr){ return oldStr.replaceAll("\\d", ""); } /** * 得到一个字符串里面的字符.A12-->12 * @param oldStr * @return */ public static int getNumFromStr(String oldStr){ return Integer.parseInt(oldStr.replaceAll("[a-zA-Z]", ""))-1; } /** * 读取指定excel中的指定sheet的某一块的数据....用于模板里面读取单元格. * @param fileName * @param sheetIndex * @param startRow * @param endRow * @param startColumn * @param endColumn */ public static List readExcel(String fileName, int sheetIndex, int startRow, int endRow, int startColumn, int endColumn) { Workbook wb = null; List allData = new ArrayList(); Cell cell = null; try { wb = Workbook.getWorkbook(new File(fileName)); Sheet sheet = wb.getSheet(sheetIndex); int rowCount = sheet.getRows(); int columnCount = sheet.getColumns(); for (int r = startRow; r < rowCount && r <= endRow; r++) {// 行 for (int c = startColumn; c < columnCount && c <= endColumn; c++) {// 列 cell = sheet.getCell(c, r); // System.out.println(cell.getContents()); allData.add(cell.getContents()); } } } catch (Exception e) { System.out.println("出现异常" + e); e.printStackTrace(); } finally { wb.close(); } return allData; } /** * 读取指定excel中的指定sheet的某一块的数据....用于模板里面读取单元格. * @param fileName * @param sheetIndex * @param startCell * @param endCell * @return */ public static List readExcel(String fileName, int sheetIndex,String startCell, String endCell) { int startRow = getNumFromStr(startCell); int endRow = getNumFromStr(endCell); int startColumn=getNumFromExcelStr(getCodeFromStr(startCell)); int endColumn = getNumFromExcelStr(getCodeFromStr(endCell)); return readExcel(fileName, sheetIndex, startRow, endRow, startColumn, endColumn); } /** * 设置excel中的sheet页全部隐藏 * @param fileName */ public static void setAllHiddenSheet(String fileName) { Workbook wb = null; try { wb = Workbook.getWorkbook(new File(fileName)); // 打开一个文件副本,并指定数据写回原文件. WritableWorkbook book = Workbook.createWorkbook(new File(fileName), wb); Sheet[] sheets = book.getSheets(); for(int i=3;i<sheets.length;i++){ Sheet ii = sheets[i]; ii.getSettings().setHidden(true); } book.write(); book.close(); } catch (Exception e) { System.out.println("出现异常" + e); e.printStackTrace(); } finally { wb.close(); System.out.print(111); } } /** * 从行号和列号,得到所在的位置字符串,例如:row=7,col=7--->i8 */ public static String getcodefromRC(int row,int col){ char[] cc = allChar.toCharArray(); return String.valueOf(cc[col])+(++row); } /** * 添加一个新的sheet到指定excel文件 * @param fileName * @param sheetName sheet的name */ public static void addNewSheet(String fileName,String sheetName) { Workbook wb = null; try { wb = Workbook.getWorkbook(new File(fileName)); // 打开一个文件副本,并指定数据写回原文件. WritableWorkbook book = Workbook.createWorkbook(new File(fileName), wb); // 创建一个新的sheet到第2页的位置 String[] sheetNames = wb.getSheetNames(); for(int i=0;i<sheetNames.length;i++){ if(sheetNames[i].equals(sheetName)){ System.out.println("已经存在了,不用添加了." ); return ; } } WritableSheet sheet = book.createSheet(sheetName, 1); sheet.addCell(new Label(0, 0, "新加的测试数据")); book.write(); book.close(); } catch (Exception e) { System.out.println("出现异常" + e); e.printStackTrace(); } finally { wb.close(); } } /** * 得到单元格的double内容,不可以直接使用cell.getContents(),因为这个方法是直接打印单元格内容 ,单元格内容可能隐藏了后面的小数点!! */ public static double getNumber(Cell cell){ NumberCell numberCell = (NumberCell)cell; double namberValue = numberCell.getValue(); return namberValue ; } /** * 如果是公式返回公式的内容,否则返回单元格字符串表面内容 * @param c * @return */ public static String getForJmulaStr(Cell c) { String ans = ""; try { System.out.println(c.getType()); if (c.getType() == CellType.NUMBER_FORMULA || c.getType() == CellType.STRING_FORMULA || c.getType() == CellType.BOOLEAN_FORMULA || c.getType() == CellType.DATE_FORMULA || c.getType() == CellType.FORMULA_ERROR) { FormulaCell nfc = (FormulaCell) c; ans = nfc.getFormula(); } else { ans = c.getContents(); } } catch (FormulaException e) { return "出现异常" + e.getMessage(); } return ans; } //得到指定位置单元格的值(普通单元格,数字单元格,日期单元格) private String getValue(Sheet sheet,int row,int col){ Cell cell=sheet.getCell(col, row); CellType cellType=cell.getType(); NumberCell numberCell = null; String cellValue = ""; //得到单元格的值 if (cellType == CellType.NUMBER) { numberCell = (NumberCell) cell; cellValue = String.valueOf(numberCell.getValue()); } else if (cellType == CellType.DATE) { cellValue = df.format(((DateCell) cell).getDate()); } else if (cellType == CellType.NUMBER_FORMULA) { // 形如:=123.232+3423.12 // 或者 =B2+123.12 NumberFormulaCell numberFormulaCell = (NumberFormulaCell) cell; cellValue = String.valueOf(numberFormulaCell.getValue()); } else { cellValue = cell.getContents(); } cellValue=cellValue.replace(" ", ""); return cellValue; } }
评论
不知道...没有做个这个需求..
</p>
<pre name="code" class="java">
//查询信息表对应的有效合同
@SuppressWarnings("unchecked")
public TKamContract getTKamContractByKamID(Long kamid){
BeanQueryCondition bqc = BeanQueryCondition.forClass(TKamContract.class);
bqc.addExpressions(Restrictions.and(Restrictions.equal("kamid", kamid),
Restrictions.equal("delflag", 0L)
// Restrictions.equal("contractstatus", 0L)//hchang 现在无需判断合同是否有效了
// Restrictions.notEqual("policytype", "6")//非超额
));
bqc.addInitFields("TKam");
List<TKamContract> result = getEntityManager().query(bqc);
// String hql = "from TKamContract t where t.TKam.kamid="+kamid+" and t.delflag=0 and t.contractstatus=0";
// TKamContract result = (TKamContract)getEntityManager().queryForObjectByHql(hql);
if(result!=null && result.size()>0){
return result.get(0);
}
else{
return null;
}
}</pre>
while(m.find()){ count++; str = str.replaceFirst(regexStr, ""); }
这个replace是没有必要的,find会更新下一次查找的开始位置
---------------------------------------------
是的,我的有问题,谢谢提醒
while(m.find()){ count++; str = str.replaceFirst(regexStr, ""); }
这个replace是没有必要的,find会更新下一次查找的开始位置
/** * Attempts to find the next subsequence of the input sequence that matches * the pattern. * * <p> This method starts at the beginning of this matcher's region, or, if * a previous invocation of the method was successful and the matcher has * not since been reset, at the first character not matched by the previous * match. * * <p> If the match succeeds then more information can be obtained via the * <tt>start</tt>, <tt>end</tt>, and <tt>group</tt> methods. </p> * * @return <tt>true</tt> if, and only if, a subsequence of the input * sequence matches this matcher's pattern */ public boolean find() { int nextSearchIndex = last; if (nextSearchIndex == first) nextSearchIndex++; // If next search starts before region, start it at region if (nextSearchIndex < from) nextSearchIndex = from; // If next search starts beyond region then it fails if (nextSearchIndex > to) { for (int i = 0; i < groups.length; i++) groups[i] = -1; return false; } return search(nextSearchIndex); }
呵呵,说实话我在项目中确实使用jxl的同时使用了正则表达式,需求是这样的:把excel中的公式转换为业务sql语句。
具体的情况具体分析,还是有机会遇到了。
我放在一起并不是表示这两个有关系,而是我的一个系统的知识的累积!呵呵,你多虑了.
还没有做到LZ系统的地步
发表评论
-
test
2018-02-01 15:19 0testtesttesttest -
spring中使用AOP进行日志记录[含代码]
2017-09-13 15:14 776spring的IOC和AOP是说的最烂的东西,尤其是后者, ... -
关于java web开发中的很多小问题集锦
2017-05-11 11:24 21511、导出excel文件,文件名的中文问题 public ... -
自定义java类重写hashcode和equals方法
2014-12-24 15:34 12671.何时需要重写equals() 当一个类有自 ... -
java的普通类重写hashcode和equals方法
2014-12-24 15:33 0class AddServe { public Stri ... -
解决问题
2013-11-18 22:54 1417启动tomcat的时候,报错如下: java 写道 严 ... -
强烈推荐一个简单而实用的数据库连接池工程
2013-07-15 23:53 1115接触过很多的数据库连接池,有d3p0,druid,都比较nb ... -
自己写的一个jedis操作模板类
2013-07-15 23:28 1418jedis是java的redis客户端程序,在spring下 ... -
打算写一个关于股票的开源小玩意
2013-03-08 23:44 0目标: 1.锻炼自己的编码能力,组织代码的能力 2.为 ... -
java应用集锦9:httpclient4.2.2的几个常用方法,登录之后访问页面问题,下载文件
2012-11-16 16:03 19951转账注明出处:http://renjie120.iteye. ... -
java应用集锦8:使用poi进行excel操作,同时支持excel2003和2007
2011-06-21 21:42 6480下面的这段代码仅仅支持excel2003,要同时支持2007和 ... -
java应用集锦7:日期函数 double精度问题 list和数组等
2010-07-20 17:51 2447转载请注明出处: http://renjie120.itey ... -
java应用集锦6:字符串base64加密解密 MD5加密
2010-07-20 16:56 5628转载请注明出处: http://renjie120.it ... -
java应用集锦5:缓存管理 单例模式 ThreadLocal
2010-07-20 12:06 6478转载请注明出处: http://renjie120.it ... -
java应用集锦4:保存大对象 上传显示进度条
2010-07-20 11:20 3514转载请注明出处: http://renjie120.it ... -
java应用集锦1:序列化 操作xml 常见IO
2010-07-12 19:42 2085转载请注明出处: http://renjie120.it ... -
java应用集锦2:反射
2010-07-07 17:52 1912在项目中多处使用到反射方法,jdk为1.5.现总结如下: 1 ... -
制作可以执行的jar包
2010-06-08 13:41 1233今天试了一下制作可执行的Jar文件的方法。 具体如下: 首 ... -
Cannot load JDBC driver class 'oracle.jdbc.driver.OracleDriver'的解决办法
2010-04-29 11:55 8728exception javax.servlet. ...
相关推荐
本篇文章将深入探讨如何使用jxl.jar库来实现Java操作Excel。 首先,jxl是一个广泛使用的Java库,它允许开发者读写Microsoft Excel文件。它的主要优势在于简单易用且功能丰富,支持多种Excel格式,包括老版本的.BIFF...
**步骤3:替换EL表达式** 遍历Excel模板中的每个单元格,检查是否存在EL表达式。如果存在,你可以使用一个EL解析器(如Apache EL或JSP EL)来计算表达式的结果,并将其替换到单元格的值中。 **步骤4:保存和输出**...
【Java Excel 操作 (jxl)】 在Java开发中,处理Excel文件时,jxl库是一个常用的选择。jxl库提供了全面的功能,可以方便地进行Excel数据的导入和导出,支持从Java程序中解释和生成Excel文件。该库不仅支持Excel 95到...
总的来说,jxl.jar是Java开发中处理Excel文件的得力工具,它提供了丰富的功能和简便的API,使得开发者可以高效地完成各种Excel操作任务。无论是简单的数据导入导出,还是复杂的格式定制,jxl.jar都能胜任。不过,...
3. **EL表达式模拟**:虽然EL主要用于JSP,但在jxl中,可能有一种类似的语言或API,允许在单元格中定义表达式,这些表达式在运行时被解析,并用实际的Java对象或数据值替换。这使得动态生成复杂Excel报告成为可能。 ...
标题"针对EXCEL操作的jxl包"表明我们关注的是一个用于处理Excel文件的Java库,名为jxl。这个库提供了在Java应用程序中读取和写入Excel文件的能力。 描述提到"jxl包可以对Excel文件进行读取和写入操作,简单实用",...
`jxl`库允许开发者使用Java语言来读写Microsoft Excel文件,无需依赖于Excel应用程序本身。本文将详细介绍如何使用`jxl`库进行Excel操作,并提供一个简单的实例。 首先,`jxl.jar`是`jxl`库的主要组件,你需要将其...
Java是一种广泛使用的编程语言,尤其在企业级应用和数据处理方面。在许多场景下,我们需要将数据导出到Excel表格以便于分析、报告或者共享。本教程将介绍如何使用Java来实现这一功能,主要依赖于jxl库,这是一个用于...
JXL库是一个广泛使用的Java库,它允许开发者读取、写入和修改Excel文件。本篇将深入探讨如何使用JXL库在Java中打印Excel报表。 首先,要使用JXL库,你需要在项目中引入它的依赖。在本例中,`jxl.jar`是JXL库的核心...
本文将对比两种主流的Java Excel处理库:jxl和Apache POI,并探讨它们的特性和适用场景。 首先,jxl是较早的Java Excel处理库,主要用于读写Excel 97-2003格式的.XLS文件。它的API简洁,易于上手,对于简单的读写...
Java Excel API,通常简称为JXL,是一种开源的Java库,允许开发者在Java应用程序中读取、创建和修改Microsoft Excel文件。与Apache POI相比,虽然JXL的功能相对较为有限,但它对中文的支持良好,且不依赖于Windows...
Java Excel API(简称jxl)是一种用于处理Excel文件的开源库,尤其适用于Java开发者。它提供了从Excel 95、97、2000等版本的文件中读取数据、创建新文件、更新已有文件的功能,且对中文支持良好,可以在非Windows...
`jxl`库是Java中一个广泛使用的库,它允许开发者方便地读取和写入Excel文件(.xls格式)。本篇将详细介绍如何利用`jxl`库来操作Excel文件,并结合实例说明如何从Excel文件中提取数据并生成TXT文件。 首先,我们需要...
【Java操作Excel之理解JXL-读取Excel.docx】的知识点主要集中在使用JXL库进行Excel文件的读取操作。JXL是一个Java API,专为处理Microsoft Excel文件设计,支持在任何Java兼容的操作系统上运行。以下是详细的解析: ...
在Java应用程序中,如果需要处理Excel数据,如数据分析、报表生成或导入导出功能,jxl.jar包就是一个非常实用的工具。这个库提供了丰富的API,允许开发者对Excel工作簿、工作表、单元格等进行操作。 一、jxl.jar包...
在Java编程环境中,读取Excel文件是常见的任务,特别是在数据处理和分析的场景下。`jxl`库是一个广泛使用的第三方库,它允许开发者轻松地读取、写入和修改Excel文件。本篇文章将深入探讨如何利用`jxl.jar`包来实现这...
Java操作Excel时,JXL库是一个非常实用的工具,它允许开发者在Java环境中方便地读取和写入Excel文件。JXL是一个开源的API,可以在任何支持Java的操作系统上运行,提供对Excel文件的动态处理能力。JXL的官方网站是...
Java 操作 Excel 之 JXL 是一个非常实用的库,用于在 Java 应用程序中创建、读取和修改 Microsoft Excel 文件。JXL 提供了一系列的 API,使得开发者能够方便地处理 Excel 数据,无论是简单的数据读写,还是复杂的...
在这个场景中,我们将探讨如何使用Java和JXL库来操作Excel,并将数据导入MySQL数据库。 1. **JXL库介绍** JXL是一个开源的Java库,它提供了对Microsoft Excel文件格式的支持。通过JXL,开发者可以创建、读取和修改...