gpt4 book ai didi

python - 使用 python 从 SQL 表生成 XML

转载 作者:行者123 更新时间:2023-11-29 12:34:24 25 4
gpt4 key购买 nike

我有一些 XML 如下:

<dd>
<persson>
<name>sam</name>
<tel>9748</tel>
</persson>
<cat>
<name>frank</name>
</cat>
</dd>

我将它解析成两个 SQL 表,一个用于标签,一个用于 pcdata。开始和停止列代表标 checkout 现和结束的位置。

Tags:
start | stop | tag
-------+------+--------
3 | 5 | name
6 | 8 | tel
2 | 9 | persson
11 | 13 | name
10 | 14 | cat
1 | 15 | dd
(6 rows)

Pcdata:
pos | pcdata
-----+--------
4 | sam
7 | 9748
12 | frank
(3 rows)

现在我想将该数据库解析回原始格式的 XML。我想编写一个函数,它接受两个表并将 XML 写到一个文件中。我正在使用 python 和 psycopg2 来执行此操作。

最佳答案

H'mmm 已解码您的“专栏”:

<dd><persson><name>sam</name><tel>9748</tel></persson>
1 2 3 4 5 6 7 8 9
<cat><name>frank</name></cat></dd>
10 11 12 13 14 15

我有一些问题要问你:你是怎么做到的?你为什么这么做?你到底想达到什么目的?请注意,您的问题标题具有误导性——“SQL 表”只是您存放特殊数据表示的地方。

这里有一些伪代码来做你想做的事:

pieces = []
result = cursor.execute("select * from tags;")
for start, step, tag in result:
pieces.append((start, "<" + tag + ">"))
pieces.append((stop, "</" + tag + ">"))
result = cursor.execute("select * from pcdata;")
for pos, pcdata in result:
pieces.append((pos, pcdata))
pieces.sort()
xml_stream = "".join(piece[1] for piece in pieces)
your_file_object.write(xml_stream)

在回答关于上面是否会在输出流中放置“位置”的问题时:不,不会;以下代码段显示了它的工作原理。这些位置仅用于将汤分类为正确的顺序。在“加入”中,piece[0]指的是位置,但没有使用,只有piece[1]这是必需的文本。

>>> pieces
[(3, '<name>'), (4, 'sam'), (5, '</name>')]
>>> ''.join(piece[1] for piece in pieces)
'<name>sam</name>'

缓和 SQL 评论问题:

虽然用 SQLite 显示,但这是标准的 SQL。如果你的数据库没有 grok ||作为串联运算符,尝试 + .

您忘记问的问题:“我如何在前面得到一个 <?xml blah-blah ?> 东西?”。答:见下文。

console-prompt>sqlite3
SQLite version 3.6.14
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> create table tags (start int, stop int, tag text);
sqlite> insert into tags values(3,5,'name');
sqlite> insert into tags values(6,8,'tel');
sqlite> insert into tags values(2,9,'persson');
sqlite> insert into tags values(11,13,'name');
sqlite> insert into tags values(10,14,'cat');
sqlite> insert into tags values(1,15,'dd');
sqlite> create table pcdata (pos int, pcdata text);
sqlite> insert into pcdata values(4,'sam');
sqlite> insert into pcdata values(7,'9748');
sqlite> insert into pcdata values(12,'frank');
sqlite> select datum from (
...> select 0 as posn, '<?xml version="1.0" encoding="UTF-8"?>' as datum
...> union
...> select start as posn, '<' || tag || '>' as datum from tags
...> union
...> select stop as posn, '</' || tag || '>' as datum from tags
...> union
...> select pos as posn, pcdata as datum from pcdata
...> )
...> order by posn;
<?xml version="1.0" encoding="UTF-8"?>
<dd>
<persson>
<name>
sam
</name>
<tel>
9748
</tel>
</persson>
<cat>
<name>
frank
</name>
</cat>
</dd>
sqlite>

关于python - 使用 python 从 SQL 表生成 XML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4139959/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com