0

我正在编写一个 python 脚本,它将:1)从企业数据库中提取 GIS 元数据 2)将元数据从 XML 解析为纯文本 3)将文本文件附加到 Socrata 中相应的已发布数据集(每月发布)4 ) 该脚本还将每月运行一次,以便企业数据集中的任何模式更改都会反映在 Socrata 上附加的纯文本元数据文件中。

我已经能够使用此处找到的一些代码成功地将文本元数据文件附加到已发布的 Socrata 数据集。问题是,每次运行脚本时,都会添加一个附加附件。我想删除现有附件并添加一个新附件,或者用新附件的内容覆盖现有附件。

我对此进行了大量研究,似乎找不到任何使用 Socrata API 管理附件的文档。有什么建议么?

4

2 回答 2

0

最终使用了相同的 API,并且能够使用以下代码替换附件:

def attach_file(self, filename, clear_metadata):
    metadata = self.metadata()
    if not metadata.has_key('attachments'):
        metadata['attachments'] = []
    # if the user wants to clear all existing attachments on dataset
    if clear_metadata:
        metadata['attachments'] = []
    response = self.multipart_post('/assets', filename)
    if not response.has_key('id'):
        print "Error uploading file to assets service: no ID returned: %s" % response
        return
    attachment = {'blobId': response['id'],
        'name': response['nameForOutput'],
        'filename': response['nameForOutput']}
    metadata['attachments'].append(attachment)
    self._request("/views/%s.json" % self.id, 'PUT', {'metadata':metadata})

def multipart_post(self, url, filename, field='file'):
    print("Running multipart_post")
    authBase64 = base64.encodestring('%s:%s' % (self.username, self.password)).replace('\n', '')

    datagen, headers       = multipart_encode({field: open(filename, "rb")})
    headers['X-App-Token'] = self.app_token
    headers['Authorization'] = "Basic %s" % authBase64
    print("url=" + url)
    request = Request("%s%s" % (self.url, url), datagen, headers)
    print(str(Request))
    response = urlopen(request).read()
    return json.loads(response)
于 2016-09-13T01:49:56.150 回答
0

我最终弄清楚了这一点。必须更改几行以清空Socrata Python库中 attach_file 函数中的附件:

def attach_file(self, filename):
    metadata = self.metadata()
    if not metadata.has_key('attachments'):
        metadata['attachments'] = []

至:

def attach_file(self, filename):
    metadata = self.metadata()
    metadata['attachments'] = []    #empty out metadata, regardless of existing metadata
于 2015-08-12T13:36:41.713 回答