- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用带有 Excel 图表的 Word 模板,我想通过 Java Apache POI 库以编程方式操作该模板。为此,我还需要能够有条件地删除存储在该模板中的图表。
基于 Axel Richters 帖子 (Removing chart from PowerPoint slide with Apache POI),我想我已经差不多完成了,但是当我想打开更新的 Word 文件时,它给出了有关不可读内容的错误。这是我到目前为止所拥有的:
PackagePart packagePartChart = xWPFChart.getPackagePart();
PackagePart packagePartWordDoc = xWPFDocument.getPackagePart();
OPCPackage packageWordDoc = packagePartWordDoc.getPackage();
// iterate over all relations the chart has and remove them
for (PackageRelationship chartrelship : packagePartChart.getRelationships()) {
String partname = chartrelship.getTargetURI().toString();
PackagePart part = packageWordDoc.getPartsByName(Pattern.compile(partname)).get(0);
packageWordDoc.removePart(part);
packagePartChart.removeRelationship(chartrelship.getId());
}
// now remove the chart itself from the word doc
Method removeRelation = POIXMLDocumentPart.class.getDeclaredMethod("removeRelation", POIXMLDocumentPart.class);
removeRelation.setAccessible(true);
removeRelation.invoke(xWPFDocument, xWPFChart);
如果我解压 Word 文件,我会正确地看到:
有人知道这里可能出了什么问题吗?
最佳答案
事实上,找到包含图表的正确段落是一个挑战。最后,为了简单起见,我添加了一个一行/一列占位符表,其中一个单元格带有文本,假设其中有“targetWordString”,直接在图表之前。通过以下函数,我可以定位该表的 BodyElementID:
private Integer iBodyElementIterator (XWPFDocument wordDoc,String targetWordString) {
Iterator<IBodyElement> iter = wordDoc.getBodyElementsIterator();
Integer bodyElementID = null;
while (iter.hasNext()) {
IBodyElement elem = iter.next();
bodyElementID = wordDoc.getBodyElements().indexOf(elem);
if (elem instanceof XWPFParagraph) {
XWPFParagraph paragraph = (XWPFParagraph) elem;
for (XWPFRun runText : paragraph.getRuns()) {
String text = runText.getText(0);
Core.getLogger("WordExporter").trace("Body Element ID: " + bodyElementID + " Text: " + text);
if (text != null && text.equals(targetWordString)) {
break;
}
}
} else if (elem instanceof XWPFTable) {
if (((XWPFTable) elem).getRow(0) != null && ((XWPFTable) elem).getRow(0).getCell(0) != null) {
// the first cell holds the name via the template
String tableTitle = ((XWPFTable) elem).getRow(0).getCell(0).getText();
if (tableTitle.equals(targetWordString)) {
break;
}
Core.getLogger("WordExporter").trace("Body Element ID: " + bodyElementID + " Text: " + tableTitle);
} else {
Core.getLogger("WordExporter").trace("Body Element ID: " + bodyElementID + " Table removed!");
}
}
else {
Core.getLogger("WordExporter").trace("Body Element ID: " + bodyElementID + " Text: ?");
}
}
return bodyElementID;
}
在代码的主要部分中,我调用此函数来定位表格,然后首先删除图表(ID +1),然后删除表格(ID)
int elementIDToBeRemoved = iBodyElementIterator(xWPFWordDoc,targetWordString);
xWPFWordDoc.removeBodyElement(elementIDToBeRemoved + 1);
xWPFWordDoc.removeBodyElement(elementIDToBeRemoved);
它需要按照这个顺序,因为一旦删除中间的数字,ID 就会重新排序,因此首先删除表格,意味着图表原则上会获得该 ID。
关于java - Apache POI : Remove Chart from Word Template file entirely,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60102573/
我是 Android 编程新手。我想给cardview添加涟漪效果。实际上我找到了解决方案,但是,在触摸cardview元素后,效果似乎并没有覆盖整个cardview。我的意思是效果突然消失并且没有到
我能否通过我自己的应用程序监听放置在 LogCat 中的消息? 例如像... // Somewhere in my application (on a background service): Log
从我们办公室到 GitHub.com 的连接通常很慢,而且文件通常很大。 有没有一种简单的方法可以只使用一台机器与 GitHub 同步,而让其他机器通过 LAN pull 和推送到那台机器? 最佳答案
如何在 flutter 中使整行可点击?我将以下代码包装在“GestureDetector”中。该行中的单个项目可点击,但小部件周围的空白区域不可点击。 if ((auth.isLoggedIn))
不知何故,Visual Studio 搜索已停止为我工作。每当我搜索“整个解决方案”中的某些文本时,我都会得到以下结果: Find all "[Whatever I was searching for
我有一个 DAO 记录集,可以很好地创建,我可以将记录从该集传输到表中,这是逐行完成的并且运行良好,但我要一次传输大量数据,因此这可能需要花费一些时间一行一行的时间很长。 有没有一种方法可以一次性传输
我知道如何从 Azure 表中获取一些表实体,如下所示: CloudStorageAccount storageAccount = CloudStorageAccount.Parse(CloudCon
我在 MainWindow.cpp 中实例化了一个 widgetClass。我想将“this”传递给这个小部件,不仅仅是(QWidget* parent),还有(MainWindow* parent)
使用最高级的 Flatspec 和 TimeLimits 特性,我可以为一行代码设置超时,如下所示: import org.scalatest.time.SpanSugar._ import org.
当使用“ipython”或“code.interact(local=locals())”时,我希望有一种方法可以保存整个程序地址空间到 pickle 文件中,以及类似的加载此类文件然后在该上下文中开始
我如何“隐藏”类的某些部分,以便使用该库的人不必包含我的类中使用的所有类型的 header 。即采用下面的 MainWindow 类,我可以拥有它吗,所以当在静态/动态库中编译时,使用该库的人不必包含
我使用以下行来获取出现特定字符串的行号: nLine=$(awk '/text/{ print NR; exit }' $1) echo "line = $nline" 返回: line = 78 现
我有一个很长的字符串S,包含几个格式如下的子字符串: [&FULL="583 - node#597 ,REALNAME="node#638"] 即: 以 [&FULL=" 开头 以 REALNAME
即使我从所有 config*.yml 文件中删除 web_profiler ...我越来越 RuntimeException: You need to enable either the SQLite
我在类方法中有一个带有文档字符串的 Python 模块,在模块文档字符串中有一个真实示例。区别在于方法文档字符串经过精心设计,可以完全重复测试,而真实世界的示例只是 Linux shell 历史记录的
我的站点使用 Wordpress 作为 CMS,它已经安装在一个子文件夹中,但我将其设置为显示在根域中。基本上,example.com 显示 example.com/wordpress 的内容。 旧的
我正在尝试为现有代码编写单元测试,这些代码编写得不好,但我发现很难进行单元测试。 def pay(self): fraud = NewFraudCheck() result, tran
我正在查询对象列表,然后将它们与子查询相关联。 我想返回子查询的结果,以及根实体。但是 我不知道如何实际返回根实体,我只能返回它的单个属性。 具体来说,这有效: this.Session.QueryO
我到处都是,似乎具有静态背景问题的 UITableView 有详细记录,但没有人有直接的解决方案?我完全用代码构建我的 TableViews,如下所示: UIViewController *t
直接取自 SQLite 的站点“该值是一个有符号整数,根据值的大小存储在 1、2、3、4、6 或 8 个字节中。” 这是否意味着如果您有 1 个需要 8 个字节的值,则该列中的所有值都将被视为 8 个
我是一名优秀的程序员,十分优秀!