V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
b1gCi
V2EX  ›  Java

请教各位 Java 有没有按照模板从 excel 获取数据的

  •  
  •   b1gCi · May 28, 2025 · 2792 views
    This topic created in 338 days ago, the information mentioned may be changed or developed.

    最近遇到一个需求,里面有很复杂的 excel 内容读取: 0. excel 文件内容类型很多种

    1. 每个 excel 文件有多个 sheet
    2. sheet 内出现可能多个表格,行数不固定
    3. 有的表格是行表头,有的是列做表头。

    看市面上的库基本都是模板写入 excel 的,各位彦祖有没有推荐能支持的从模板读取 excel 的?

    或者有其他更好的解决方案?

    不行只能硬编码了 : <

    12 replies    2025-05-30 07:56:03 +08:00
    Need4more
        1
    Need4more  
       May 28, 2025
    数据你能控制吗?能控制的话你预先给个模板让用户按模板填数据,然后用 easyexcel 解析
    b1gCi
        2
    b1gCi  
    OP
       May 28, 2025
    @Need4more 数据内容格式不能修改,别的好处理,就是一个 sheet 多个表格的时候麻烦
    Mandelo
        3
    Mandelo  
       May 28, 2025
    Apache POI
    dode
        4
    dode  
       May 29, 2025
    使用表头关键字匹配度灵魂识别表头,循环提取数据
    DreamSpace
        5
    DreamSpace  
       May 29, 2025
    同意 4L ,我也写过,有些情况在表头里可能还要再判断下合并单元格,很魔法的设计
    b1gCi
        6
    b1gCi  
    OP
       May 29, 2025
    @dode @DreamSpace 目前是这么实现中,就是做法不够通用,所以出来再看看大家想法💡
    jinjiang2024
        7
    jinjiang2024  
       May 29, 2025
    如何能简单控制模版 那就还有操作的空间
    jinjiang2024
        8
    jinjiang2024  
       May 29, 2025
    如果能控制模版 我会在表头上做标记(比如隐藏列标记、隐形字体(白色)、批注写标记、命名区域),人看的时候不用直观看出就行。
    Mjhhh
        9
    Mjhhh  
       May 29, 2025
    @dode 我遇到过类似的需求,也是这么做,感觉没什么银弹
    csx163
        10
    csx163  
       May 29, 2025
    excel 稍微复杂点的建议还是用 vba ,XBRL 什么
    b1gCi
        11
    b1gCi  
    OP
       May 30, 2025
    @csx163 😂就是财务习惯了 excel ,数据对外得用 xbrl 才来做解析的
    b1gCi
        12
    b1gCi  
    OP
       May 30, 2025
    @jinjiang2024 你这方法不错的,可惜了我这边不能修改模板
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2382 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 34ms · UTC 02:01 · PVG 10:01 · LAX 19:01 · JFK 22:01
    ♥ Do have faith in what you're doing.