- Siêu lớp và danh mục iOS/Objective-C
- object-c - -1001 lỗi khi NSURLSession vượt qua httpproxy và /etc/hosts
- java - Nhận địa chỉ url bằng lớp mạng
- ios - Âm thanh không phát trong thông báo đẩy
Tôi đang phát triển một ứng dụng web đọc dữ liệu từ tệp excel (xlsx). Tôi đang sử dụng POI để đọc bảng excel. Vấn đề là khi tôi cố đọc tệp excel, máy chủ đưa ra lỗi sau:
Tệp excel tôi đang cố đọc có kích thước gần 80 MB. Có giải pháp nào cho vấn đề này không?
Trên thực tế, người dùng đang tải tệp lên và ứng dụng đang cố đọc tệp sau khi lưu tệp vào đĩa. Đoạn mã tôi sử dụng để thử nghiệm là:
Tệp đã lưuFile = Tệp mới (file_path);
FileInputStream fis = null;
thử {
fis = FileInputStream mới(savedFile);
XSSFWorkbook xWorkbook = XSSFWorkbook mới(fis);
XSSFSheet xSheet = xWorkbook.getSheetAt(5);
Hàng lặp = xSheet.rowIterator();
trong khi (rows.hasNext()) {
XSSFRow row = (XSSFRow) row.next();
Các ô lặp = row.cellIterator();
Danh sách dữ liệu = new ArrayList();
trong khi (cell.hasNext()) {
Ô XSSFCell = (XSSFCell) cell.next();
System.out.println(cell.getStringCellValue());
data.add(ô);
}
}
} catch (IOException e) {
e.printStackTrace();
}
câu trả lời hay nhất
Một điều sẽ khác là thời gian tệp được mở. Nếu bạn có một tệp, hãy chuyển nó vào! Việc sử dụng inputStream yêu cầu lưu mọi thứ vào bộ nhớ, việc này sẽ chiếm dung lượng. Vì bạn không cần đệm nên không cần!
Nếu bạn đang chạy bản dựng POI hàng đêm mới nhất thì điều đó rất đơn giản. Mã của bạn trở thành:
Tệp tệp = Tệp mới (file_path);
OPCPackage opcPackage = OPCPackage.open(file);
Sổ làm việc XSSFWorkbook = XSSFWorkbook mới(opcPackage);
Mặt khác, nó rất giống nhau:
Tệp tệp = Tệp mới (file_path);
OPCPackage opcPackage = OPCPackage.open(file.getAbsolutePath());
Sổ làm việc XSSFWorkbook = XSSFWorkbook mới(opcPackage);
Điều này sẽ giải phóng một số bộ nhớ cho bạn, có thể là đủ. Nếu không, và bạn không thể tăng đủ dung lượng vùng nhớ heap Java để đáp ứng thì bạn sẽ phải ngừng sử dụng XSSF UserModel.
Ngoài UserModel thân thiện với người dùng hiện tại mà bạn đang sử dụng, POI còn hỗ trợ xử lý tệp cấp thấp hơn. Cách tiếp cận cấp thấp hơn này khó sử dụng hơn vì bạn không có nhiều trợ giúp khác nhau yêu cầu toàn bộ tệp trong bộ nhớ. Tuy nhiên, khi bạn xử lý tệp dưới dạng luồng, bộ nhớ sẽ hiệu quả hơn nhiều. Để bắt đầu, hãy xem Phần hướng dẫn sử dụng XSSF và SAX (API sự kiện)trên trang web POI. Hãy thử và xem các ví dụ khác nhau.
Về ngoại lệ java.lang.outofmemory khi sử dụng POI để đọc tệp excel (xlsx), chúng tôi đã tìm thấy một câu hỏi tương tự trên Stack Overflow: https://stackoverflow.com/questions/11118703/
在 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 的新手。有人可以解释我错过了什么吗? 以下
Đã đóng cửa. Sự cố này yêu cầu chi tiết gỡ lỗi. Câu trả lời không được chấp nhận vào thời điểm này. Chỉnh sửa câu hỏi để bao gồm hành vi mong muốn, một vấn đề hoặc lỗi cụ thể và
我的代码在下面给出了一个错误; 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
Tôi là một lập trình viên xuất sắc, rất giỏi!