2

我有一个包含一堆 XML 文档的目录,并希望将它们全部放入一个容器中。换句话说,我需要做这样的事情:

dbxml> putDocument tests/*.xml

我已经编写了一个 GUI 程序来做到这一点,但是主机服务器没有安装 X-windows,所以必须在命令行中。

4

3 回答 3

1

在将某些 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'

希望有帮助

于 2012-08-21T10:58:59.397 回答
0

最终使用了一个列出文件并将所有内容放入数据库的脚本。

于 2012-01-10T13:22:25.347 回答
0

您可以让 shell 脚本将 XML 文件列表写入另一个文件,然后使用 -f 选项调用dbxml_load_container 。

于 2011-07-01T21:02:30.773 回答