【问题标题】:Apache POI - setting left/right print margin in ExcelApache POI - 在 Excel 中设置左/右打印边距
【发布时间】:2014-01-07 08:14:07
【问题描述】:

这可能 - 使用 apache POI - 为 Excel 工作表设置左侧或右侧打印边距吗?

默认边距很大。我在 XSSFPrintSetup 中既看不到 setLeftMargin 也看不到 setRightMargin,只能看到页眉和页脚:

    XSSFPrintSetup printSetup = (XSSFPrintSetup) sheet.getPrintSetup();
    printSetup.setHeaderMargin(0.5D);
    printSetup.setFooterMargin(0.5D);

有哪位好心的朋友可以帮帮我吗?

【问题讨论】:

    标签: java excel apache-poi


    【解决方案1】:

    工作表边距不包含在XSSFPrintSetup 对象中,而是包含在XSSFSheet 本身上。使用SheetgetMarginsetMargin 方法,为上/左/下/右/页眉/页脚边距传递适当的Sheet 常量。以英寸为单位设置和获取边距。

    double leftMarginInches = sheet.getMargin(Sheet.LeftMargin);
    sheet.setMargin(Sheet.RightMargin, 0.5 /* inches */ );
    

    【讨论】:

      【解决方案2】:

      枚举现在是 MarginType.LeftMargin, -RightMargin

      double leftMargin = sheet.GetMargin(MarginType.LeftMargin);
      double rightMargin = sheet.GetMargin(MarginType.RightMargin);
      

      更新:

      这段代码前面的代码是:

                  var workbook = new XSSFWorkbook();
                  var sheet = workbook.CreateSheet(sheetname);
                  double leftMargin = sheet.GetMargin(MarginType.LeftMargin);
                  double rightMargin = sheet.GetMargin(MarginType.RightMargin);
      

      这确实是 NPOI。

      【讨论】:

      • 你确定你在这里谈论的是同一个软件吗?只有Apache POI method is Sheet.getMargin not Sheet.GetMargin,POI 中没有定义MarginType 枚举
      • 是的,我从我的工作示例中添加了更多代码来演示起源。
      • OP 已将他们的问题标记为java,因此可能是在询问 Apache POI 而不是 NPOI。因此,您的答案似乎充其量是令人困惑的,或者在最坏的情况下是完全错误的:/
      • 这篇文章是在 NPOI 的搜索下出现的。虽然我很欣赏它是 POI,而不是 .NET 包装器 NPOI,但这些方法是相似的,并且其他人在进行我所做的相同搜索时会找到相同的主题,也许是他们正在寻找的真正答案。 NPOI IS POI:就在.NET界面下。
      • 如今它们是完全不同的代码库,在这种情况下,Apache POI (Java) 中缺少 MarginType 接口就证明了这一点,这意味着您的答案不起作用!
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2011-11-22
      • 1970-01-01
      • 1970-01-01
      • 2017-02-01
      • 2013-09-02
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多