Import databricks notebook (dynamic content) using workspace api import method(使用工作区API导入方法导入数据库笔记本(动态内容))
本文介绍了使用工作区API导入方法导入数据库笔记本(动态内容)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我要使用工作区API导入方法导入Databricks笔记本。笔记本的内容应该是动态的。我正在尝试使用以下代码,但出现错误:
错误的请求
请求包含无效的json正文。我已经尝试将content
转换为Base64编码的数据,并在有效负载中传递它,但仍给出相同的错误。我主要想实现的是,我想动态生成笔记本的内容。
import requests
import os
import json
ctx = json.loads(dbutils.notebook.entry_point.getDbutils().notebook().getContext().toJson())
host_name = ctx['extraContext']['api_url']
host_token = ctx['extraContext']['api_token']
notebook_path = ctx['extraContext']['notebook_path']
new_path = os.path.join(os.path.dirname(notebook_path), 'New name')
data = {
"content": "print(hellow world)",
"path": new_path,
"language": "PYTHON",
"overwrite": true,
"format": "SOURCE"
}
response = requests.post(
'{host_name}/api/2.0/workspace/import',
headers={'Authorization': f'Bearer {host_token}'},
data = data
).json()
推荐答案
这里有几个问题:
- 根据documentation,
content
字段应该是Base64编码的,所以您需要这样做:
import base64
data = {
"content": base64.b64encode("print(hellow world)".encode()),
...
}
- 有效负载应该是JSON,但您使用的是
data
参数,该参数将数据作为多部分表单数据发送(请参见docs)。您需要使用json
参数:
response = requests.post(
f'{host_name}/api/2.0/workspace/import',
headers={'Authorization': f'Bearer {host_token}'},
json = data
).json()
- 您正在尝试替换主机名,但您只使用了字符串,而不是f字符串,因此您需要将
'{host_name}/api/2.0/workspace/import'
更改为f'{host_name}/api/2.0/workspace/import'
这篇关于使用工作区API导入方法导入数据库笔记本(动态内容)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:使用工作区API导入方法导入数据库笔记本(动态内
基础教程推荐
猜你喜欢
- Python h5py-为什么我收到广播错误? 2022-09-21
- 跟在带量词的前瞻后面有什么作用? 2022-09-22
- 在OpenCV中放大后,Python会捕捉图像的特定部分 2022-09-22
- 如何防止Groupby超越指数? 2022-09-22
- 从顶点坐标创建三角网格 2022-09-21
- 如何在hdf5文件的多个组之间拆分数据? 2022-09-21
- 如何将RPC与Volttron配合使用 2022-09-21
- 使用工作区API导入方法导入数据库笔记本(动态内 2022-09-21
- 在 pandas 中使用带有多重索引的.loc 2022-09-22
- 获取多索引中某个级别的最后一个元素 2022-09-22