关于java代码解析excel,使用sax解析

关于excel解析:
目前网上大多数方法都是利用 apache.poi来解析。
但是上个星期由于一些问题导致内存溢出,原因是poi解析会读取所有的单元格,每一个单元格作为一个对象,而excel中的一些操作会导致没有数据的单元格也被读取,最终导致系统GG。

这是我用于测试的excel:在这里插入图片描述
在这里插入图片描述

将文件重命名后(加后缀.zip):
在这里插入图片描述
再打开:在这里插入图片描述
在这里插入图片描述在这里插入图片描述

xl中包含了excel中的绝大数内容,worksheets中的sheet.xml包含了大部分的数据,sharedString.xml
则包含了sheet.xml中的某些单元格对应的字符串。
目前博主对于excel的了解仅限于此,所以写的代码不是很好,请谅解。

在找了许多资料后和试了几种方法,最终写出来的代码,目前能解析出对应的数据,但是还不知道有什么问题
博主实力不济,仅供参考,有错误请指正,谢谢

ps:关于sheet文件与sharedString文件如何一起读取赋值,还有终止sax解析目前没有解决,希望大家能指点指点

代码



import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.zip.ZipEntry;
import java.util.zip.ZipFile;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;

/**
 * 读取Excel文件--- 不稳定
 */
public class ExcelIO {
   
    /**
     * @param 文件地址,列数,行数 无法控制行数,当文件数据过多超过所传参数,报错,终止读取 将所读取的数据以字符串的形式存储
     * @return 返回一个字符串数组列表
     */
    static List<String[]> readExcelIo(String url, int proNum, int rowNum)
            throws IOException, ParserConfigurationException, SAXException {
   
        // 读取Excel文件
        ZipFile file = new ZipFile(url);
        
        // 压缩文件读取,可以读取到压缩文件中的具体文件
        // 这里只读第一个Sheet,在workbook.xml中有sheet的记录,读取workbook文件可以获得
        ZipEntry sheet1File = file.getEntry("xl/worksheets/sheet1.xml");
        
        ZipEntry sharedStringFile = file.getEntry("xl/sharedStrings.xml");

        // sheet输入流
        InputStream sheet1In = file.getInputStream(sheet1File);

        // sharedString输入流
        InputStream sharedStringIn = file.getInputStream(sharedStringFile);

        // sax解析
        SAXParserFactory sax = SAXParserFactory.newInstance();
        SAXParser parser = sax.newSAXParser();

        // 创建sheet文件t处理对象
        SheetHandler sheet1Handler = new SheetHandler(proNum, rowNum);
        parser.parse(sheet1In, sheet1Handler);

        // 创建sharedString文件处理对象
        SharedStringHandler sharedStringHandler = new SharedStringHandler();
        parser.parse
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在Java使用SAX解析XML,你可以按照以下步骤进行操作: 1. 导入相关的类和包,如`javax.xml.parsers.SAXParser`和`javax.xml.parsers.SAXParserFactory`。 2. 创建`SAXParserFactory`的实例。 3. 通过调用`SAXParserFactory`的`newSAXParser()`方法创建一个解析器。 4. 获取需要解析的XML文档,并创建一个`File`对象来表示该文档。 5. 创建一个自定义的`SAXHandler`类,该类继承自`DefaultHandler`类,并重写需要的回调方法来处理XML元素和数据。 6. 调用解析器的`parse()`方法,传入文件和自定义的`SAXHandler`对象作为参数,开始解析XML文档。 你可以参考以下示例代码: ```java import java.io.File; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; public class TestDemo { public static void main(String[] args) throws Exception { // 1.实例化SAXParserFactory对象 SAXParserFactory factory = SAXParserFactory.newInstance(); // 2.创建解析SAXParser parser = factory.newSAXParser(); // 3.获取需要解析的文档,生成解析器,最后解析文档 File f = new File("books.xml"); SaxHandler dh = new SaxHandler(); parser.parse(f, dh); } } ``` 请注意,上述代码中的`SaxHandler`是一个自定义的类,你需要根据自己的需求来实现该类,以便在解析XML时处理相应的元素和数据。 XML文档如下所示: ```xml <?xml version="1.0" encoding="UTF-8"?> <books> <book id="001"> <title>Harry Potter</title> <author>J K. Rowling</author> </book> <book id="002"> <title>Learning XML</title> <author>Erik T. Ray</author> </book> </books> ``` 希望以上信息能够帮到你。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [java使用sax解析xml的解决方法](https://download.csdn.net/download/weixin_38747216/12815749)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [在java使用sax解析xml](https://blog.csdn.net/weixin_33884611/article/details/86303531)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值