- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果我在一个文件夹中放入超过 5 个 excel 文件,我会得到这个
java.lang.OutOfMemoryError: Java heap space.
我总共有 40 个 Excel 文件,每个文件可能包含 5 到 10 张。我的代码将找出 Excel 文件中的错误并将其记录在 Error.txt 文件中。
public class Hvd {
public static int getExcelColumnNumber(String column) {
int result = 0;
for (int i = 0; i < column.length(); i++) {
result *= 26;
result += column.charAt(i) - 'A' + 1;
}
return result;
}
public static String getExcelColumnName(int number) {
final StringBuilder sb = new StringBuilder();
int num = number - 1;
while (num >= 0) {
int numChar = (num % 26) + 65;
sb.append((char)numChar);
num = (num / 26) - 1;
}
return sb.reverse().toString();
}
public static void main(String[] args) {
try {
//File directory = new File("C://Users//zkuwscr//Documents//new practice tests//Regression_Dev_Dec12th");
File directory = new File("C://Users//kondeti.venkatarao//Documents//Regresion_sheets");
File[] files = directory.listFiles();
//File errorBW = new File("C://Users//zkuwscr//Documents//new practice tests//Regression_Dev_Dec12th//ErrorBW.txt");
File errors = new File("C://Users//kondeti.venkatarao//Documents//Regresion_sheets//Error.txt");
FileOutputStream errorsFileOutputStream = new FileOutputStream(errors);
BufferedWriter errorsBufferedWriter = new BufferedWriter(new OutputStreamWriter(errorsFileOutputStream));
File mismatch = new File("C://Users//kondeti.venkatarao//Documents//Regresion_sheets//Mismatch.txt");
FileOutputStream mismatchFileOutputStream = new FileOutputStream(mismatch);
BufferedWriter mismatchBufferedWriter = new BufferedWriter(new OutputStreamWriter(mismatchFileOutputStream));
for (File file : files) {
if (file.getName().endsWith(".xlsx")) {
//FileInputStream fis = new FileInputStream(file);
// Create Workbook instance holding reference to .xlsx file
OPCPackage pkg = OPCPackage.open(file);
XSSFWorkbook workbook = new XSSFWorkbook(pkg);
int i = 1;
while (i < workbook.getNumberOfSheets()) {
// System.out.println(workbook.getNumberOfSheets());
// Get first/desired sheet from the workbook
XSSFSheet sheet = workbook.getSheetAt(i);
// Iterate through each rows one by one
Iterator<Row> rowIterator = sheet.iterator();
while (rowIterator.hasNext()) {
Row row = rowIterator.next();
// For each row, iterate through all the columns
Iterator<Cell> cellIterator = row.cellIterator();
while (cellIterator.hasNext()) {
Cell cell = cellIterator.next();
// Check the cell type and format accordingly
switch (cell.getCellType()) {
/*
* case Cell.CELL_TYPE_NUMERIC:
* System.out.print(cell.getNumericCellValue());
* break; case Cell.CELL_TYPE_STRING:
* System.out.print(cell.getStringCellValue());
* break;
*/
// case Cell.CELL_TYPE_FORMULA:
case Cell.CELL_TYPE_FORMULA:
if (cell.getCellFormula().startsWith("IF("))
if (sheet.getRow(row.getRowNum())
.getCell(cell.getColumnIndex())
.getRawValue().equals("1")) {
HashSet<Integer> number= new HashSet<Integer>();
ArrayList<String> alphas=new ArrayList<String>();
String formula=sheet.getRow(row.getRowNum()).getCell(cell.getColumnIndex()).toString();
Matcher digitMatcher = Pattern.compile("\\d+").matcher(formula);
Matcher alphabetMatcher = Pattern.compile("[a-zA-Z]+").matcher(formula);
while(alphabetMatcher.find()) {
if(!alphabetMatcher.group().equals("TYPE"))
alphas.add(alphabetMatcher.group());
}
int countIF = Collections.frequency(alphas, "IF");
int countABS = Collections.frequency(alphas, "ABS");
HashSet<String> alphaSet=new HashSet<String>(alphas);
if(countIF!=5 && countIF!=6)
alphaSet.remove("IF");
if(countABS != 3 && countABS!=4)
alphaSet.remove("ABS");
while(digitMatcher.find()) {
if(!digitMatcher.group().equals("0") && !digitMatcher.group().equals("1") && !digitMatcher.group().equals("01"))
number.add(Integer.parseInt(digitMatcher.group()));
}
ArrayList<Integer> numberList = new ArrayList<Integer>(number);
ArrayList<String> alphaList = new ArrayList<String>(alphaSet);
System.out.println("alphaSet"+alphaSet);
System.out.println("numberList"+numberList);
int rowIndex=numberList.get(0)-1;
int originalColumnIndex = getExcelColumnNumber(alphaList.get(0))-1;
int referenceColumnIndex = getExcelColumnNumber(alphaList.get(1))-1;
if(originalColumnIndex > referenceColumnIndex){
int temp = referenceColumnIndex;
referenceColumnIndex =originalColumnIndex;
originalColumnIndex=temp;
}
//System.out.println(sheet.getRow(row.getRowNum()));
System.out.println("File Name: "+ file.getName());
System.out.println("Sheet Name: "+ sheet.getSheetName());
System.out.println(sheet.getRow(row.getRowNum()).getCell(cell.getColumnIndex()).toString());
if(sheet.getRow(rowIndex).getCell(originalColumnIndex).getCellFormula().equals(""))
System.out.println("please help me out");
System.out.println("Function Name: "+ sheet.getRow(rowIndex).getCell(originalColumnIndex).getCellFormula());
System.out.println("row indext"+rowIndex);
System.out.println("original column index"+originalColumnIndex);
System.out.println("ref column index"+referenceColumnIndex);
/*System.out.println("File Name: "
+ file.getName());
System.out.println("Sheet Name: "
+ sheet.getSheetName());
System.out.println(cell
.getCellFormula());*/
if(sheet.getRow(rowIndex).getCell(originalColumnIndex).getCellFormula().contains("qCRA_") && sheet.getRow(rowIndex).getCell(originalColumnIndex).getRawValue().contains("Error:")){
errorsBufferedWriter.newLine();
errorsBufferedWriter.write("File Name: "+ file.getName());
errorsBufferedWriter.newLine();
errorsBufferedWriter.write("Sheet Name: "+ sheet.getSheetName());
errorsBufferedWriter.newLine();
errorsBufferedWriter.write("Function Name: "+ sheet.getRow(rowIndex).getCell(originalColumnIndex).getCellFormula());
errorsBufferedWriter.newLine();
errorsBufferedWriter.write("Cell Number: "+getExcelColumnName(originalColumnIndex+1)+numberList.get(0));
errorsBufferedWriter.newLine();
errorsBufferedWriter.write("Orginal Value : "+sheet.getRow(rowIndex).getCell(originalColumnIndex).getRawValue());
errorsBufferedWriter.newLine();
errorsBufferedWriter.write("Reference Value : "+sheet.getRow(rowIndex).getCell(referenceColumnIndex));
errorsBufferedWriter.newLine();
} else {
mismatchBufferedWriter.newLine();
mismatchBufferedWriter.write("File Name: "+ file.getName());
mismatchBufferedWriter.newLine();
mismatchBufferedWriter.write("Sheet Name: "+ sheet.getSheetName());
mismatchBufferedWriter.newLine();
mismatchBufferedWriter.write("Function Name: "+ sheet.getRow(rowIndex).getCell(originalColumnIndex).getCellFormula());
mismatchBufferedWriter.newLine();
mismatchBufferedWriter.write("Cell Number: "+getExcelColumnName(originalColumnIndex+1)+numberList.get(0));
mismatchBufferedWriter.newLine();
mismatchBufferedWriter.write("Orginal Value : "+sheet.getRow(rowIndex).getCell(originalColumnIndex).getRawValue());
mismatchBufferedWriter.newLine();
mismatchBufferedWriter.write("Reference Value : "+sheet.getRow(rowIndex).getCell(referenceColumnIndex));
mismatchBufferedWriter.newLine();
}
}
break;
}
cell=null;
}
row=null;
}
i++;
//fis.close();
pkg.close();
sheet=null;
}
workbook=null;
}
}
errorsBufferedWriter.close();
errorsFileOutputStream.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
最佳答案
BufferedWriter
甚至 PrintStream
)。无需将所有输出保存在内存中。仅此一项就可以解决您的问题。关于java - 在线程 "main"java.lang.OutOfMemoryError : Java heap space 中出现异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27483546/
在 Tomcat 6/Ubuntu 12.04 上启动 Grails 2.1.0 应用程序时出现以下错误。 Error 500 - Internal Server Error. groovy.lang
在运行 Storm 拓扑时,我收到此错误。拓扑完美运行 5 分钟,没有任何错误,然后失败。我正在使用 Config.TOPOLOGY_TICK_TUPLE_FREQ_SECS as 300 sec i
我有一个 jsp 代码在其中一台机器上运行良好。但是当我复制到另一台机器时,我得到了这个 no such method found 异常。我是 Spring 的新手。有人可以解释我错过了什么吗? 以下
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我的代码在下面给出了一个错误; Exception in thread "main" java.lang.NoSuchMethodError: com/myApp/Client.cypherCBC(L
我正在尝试一个 Restful web 服务示例,所以当我要访问 url 时,我遇到了异常 java.lang.NoSuchMethodError: jersey.repackaged.com.goo
我正在将一个 Spring web 项目转换为一个 Maven 项目,但我收到了这个错误: java.lang.NoSuchMethodError: org.jboss.logging.Logger.
在我的项目中,我有一个像这样的枚举: public enum MyEnum { FIRST(1), SECOND(2); private int value; private MyEnum(int v
我创建了这个简单的示例,用于读取 Linux 正常运行时间: public String getMachineUptime() throws IOException { String[] di
我正在使用 Eclipse,并且正在使用 Java。我的目标是使用 bogoSort 方法对 vector 进行排序在一个 vector (vectorExample)中适应我的 vector 类型,
我正在运行以下查询。它显示一条错误消息。如何解决这个错误? ListrouteList=null; List companyList = session.createS
我有以下模型类: @Entity @Table(name="user_content") @org.hibernate.annotations.NamedQueries({ @org.
我有那个错误。这是我的代码: GmailSettingsService service = new GmailSettingsService(APPLICATION_NAME, DOMAIN_NAME
实际上我在执行我的java程序时遇到了下面提到的错误 Exception in thread "pool-1-thread-1" java.lang.ClassCastException: jav
java.lang.ClassCastException: java.lang.Float cannot be cast to java.lang.String 我在以下代码中遇到此异常: Strin
我正在尝试从 linkedhashset 中检索随机元素。下面是我的代码,但它每次都给我异常。 private static void generateRandomUserId(Set userIds
我已经完成了 Android 中的代码: List spinnerArray = new ArrayList(); for (int i = 0; i item = (LinkedTreeMap)
这个问题已经有答案了: Explanation of ClassCastException in Java (12 个回答) 已关闭 6 年前。 我已经编写了 java 到 Json 的代码,同时从页
这个问题在这里已经有了答案: ClassCastException java.lang.Long cannot be cast to clojure.lang.IFn (4 个答案) 关闭 6 年前
我在运行时遇到问题来编译这段代码,这给我一个错误,java.lang.Integer 无法转换为 Java.lang.Double。如果有人帮助我更正此代码,我将非常高兴 double x; pu
我是一名优秀的程序员,十分优秀!