怎么将html转换为ipynb,IPython笔记本:将HTML笔记本转换为ipynb

我最近使用BeautifulSoup和JSON将html笔记本转换为ipynb。诀窍是查看笔记本的JSON模式并模拟它。代码只选择输入代码单元格和标记单元格

这是我的密码from bs4 import BeautifulSoup

import json

import urllib.request

url = 'http://nbviewer.jupyter.org/url/jakevdp.github.com/downloads/notebooks/XKCD_plots.ipynb'

response = urllib.request.urlopen(url)

# for local html file

# response = open("/Users/note/jupyter/notebook.html")

text = response.read()

soup = BeautifulSoup(text, 'lxml')

# see some of the html

print(soup.div)

dictionary = {'nbformat': 4, 'nbformat_minor': 1, 'cells': [], 'metadata': {}}

for d in soup.findAll("div"):

if 'class' in d.attrs.keys():

for clas in d.attrs["class"]:

if clas in ["text_cell_render", "input_area"]:

# code cell

if clas == "input_area":

cell = {}

cell['metadata'] = {}

cell['outputs'] = []

cell['source'] = [d.get_text()]

cell['execution_count'] = None

cell['cell_type'] = 'code'

dictionary['cells'].append(cell)

else:

cell = {}

cell['metadata'] = {}

cell['source'] = [d.decode_contents()]

cell['cell_type'] = 'markdown'

dictionary['cells'].append(cell)

open('notebook.ipynb', 'w').write(json.dumps(dictionary))

这里是print(soup.div)输出的一部分div class="container">

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值