我有一个包含一堆 XML 文档的目录,并希望将它们全部放入一个容器中。换句话说,我需要做这样的事情:
dbxml> putDocument tests/*.xml
我已经编写了一个 GUI 程序来做到这一点,但是主机服务器没有安装 X-windows,所以必须在命令行中。
我有一个包含一堆 XML 文档的目录,并希望将它们全部放入一个容器中。换句话说,我需要做这样的事情:
dbxml> putDocument tests/*.xml
我已经编写了一个 GUI 程序来做到这一点,但是主机服务器没有安装 X-windows,所以必须在命令行中。
在将某些 XML 文档重新加载到我当前的应用程序数据库中时,我会做类似的事情。如果所有文件共享一个共同的命名约定,它会有所帮助。在 python 中,您可以使用以下脚本将 doc001.xml 添加到 doc009.xml:
from bsddb3.db import *
from dbxml import *
#Load source files 001 - 009
sourceDir = 'C:/directory-containing-xml-docs'
fileRange = range(1,10)
for x in fileRange:
mycontainer = mymgr.openContainer("myDB.dbxml")
xmlucontext = mymgr.createUpdateContext()
xmlinput = mymgr.createLocalFileInputStream(sourceDir + "doc00" + str(x) + ".xml")
mycontainer.putDocument("doc00" + str(x) + ".xml", xmlinput, xmlucontext)
print 'Added: ' + str(x)
del mycontainer
print '1 - 9 Added'
希望有帮助
最终使用了一个列出文件并将所有内容放入数据库的脚本。
您可以让 shell 脚本将 XML 文件列表写入另一个文件,然后使用 -f 选项调用dbxml_load_container 。