我正在通过python和Confluence API更新Confluence页面。
我找到了一个将数据写入我的页面的功能,不幸的是它创建了一个包含我的数据的新页面,旧页面变成了一个存档版本。
我一直在搜索参考资料,但无法看到我获取新页面的原因,而不是将数据附加到页面末尾。我能想到的唯一解决方案是复制正文并将新数据附加到其中,然后创建新页面......但我认为应该有一种方法可以追加。
我找到/正在利用的写函数代码如下:
def write_data(auth, html, pageid, title = None):
info = get_page_info(auth, pageid)
print ("after get page info")
ver = int(info['version']['number']) + 1
ancestors = get_page_ancestors(auth, pageid)
anc = ancestors[-1]
del anc['_links']
del anc['_expandable']
del anc['extensions']
if title is not None:
info['title'] = title
data = {
'id' : str(pageid),
'type' : 'page',
'title' : info['title'],
'version' : {'number' : ver},
'ancestors' : [anc],
'body' : {
'storage' :
{
'representation' : 'storage',
'value' : str(html),
}
}
}
data = json.dumps(data)
pprint (data)
url = '{base}/{pageid}'.format(base = BASE_URL, pageid = pageid)
r = requests.put(
url,
data = data,
auth = auth,
headers = { 'Content-Type' : 'application/json' }
)
r.raise_for_status()
我开始认为复制/附加到身体是可选的,但希望其他人遇到过这个问题。
答案 0 :(得分:0)
不是一个优雅的解决方案,但我带着旧身体的副本并附加选项。
基本上,写了一个简单的函数来返回现有的主体:
def get_page_content(auth, pageid):
url = '{base}/{pageid}?expand=body.storage'.format(
base = BASE_URL,
pageid = pageid)
r = requests.get(url, auth = auth)
r.raise_for_status()
return (r.json()['body']['storage']['value'])
在此示例中,只需将(+ =)一个新字符串附加到现有主体。
def write_data(auth, html, pageid, title = None):
info = get_page_info(auth, pageid)
page_content = get_page_content(auth, pageid)
ver = int(info['version']['number']) + 1
ancestors = get_page_ancestors(auth, pageid)
anc = ancestors[-1]
del anc['_links']
del anc['_expandable']
del anc['extensions']
page_content += "\n\n"
page_content += html
if title is not None:
info['title'] = title
data = {
'id' : str(pageid),
'type' : 'page',
'title' : info['title'],
'version' : {'number' : ver},
'ancestors' : [anc],
'body' : {
'storage' :
{
'representation' : 'storage',
'value' : str(page_content),
}
}
}
data = json.dumps(data)
url = '{base}/{pageid}'.format(base = BASE_URL, pageid = pageid)
r = requests.put(
url,
data = data,
auth = auth,
headers = { 'Content-Type' : 'application/json' }
)
r.raise_for_status()
print "Wrote '%s' version %d" % (info['title'], ver)
print "URL: %s%d" % (VIEW_URL, pageid)
应该注意,因为这是一个汇合体的帖子,传递的文本是html。换行的'\ n'不起作用,你需要传递'< br \>'等...
如果有人有更优雅的解决方案,欢迎提出建议。
丹