Project Icon

jupyterlab-github

JupyterLab扩展实现直接浏览和使用GitHub仓库

jupyterlab-github为JupyterLab提供了一个新的文件浏览器标签,允许直接访问GitHub仓库。用户可以浏览组织和个人仓库,打开并运行文件,包括笔记本和文本文件。这个扩展简化了从GitHub获取代码和数据的过程,提高了开发效率,但不包括完整的GitHub功能。它为数据科学家和开发者提供了一种在JupyterLab环境中便捷使用GitHub资源的方法。

JupyterLab GitHub

Binder

一个用于访问GitHub仓库的JupyterLab扩展。

这个扩展的功能

安装此扩展后,JupyterLab左侧区域将添加一个额外的文件浏览器标签。这个文件浏览器允许您选择GitHub组织和用户,浏览他们的仓库,并打开这些仓库中的文件。如果这些文件是笔记本,您可以像运行其他笔记本一样运行它们。您还可以将内核附加到文本文件并运行它们。基本上,您应该能够打开仓库中JupyterLab可以处理的任何文件。

以下是插件在GitHub上打开这个文件的截图: gitception

这个扩展不提供的功能

这不是一个提供完整GitHub访问功能的扩展,如保存文件、提交更改、复刻仓库等。要实现这些功能,它需要或多或少地重新创造GitHub网站,这将大大增加扩展的复杂性。

关于速率限制的说明

此扩展既有客户端组件(即与JupyterLab打包的JavaScript),也有服务器端组件(即添加到Jupyter服务器的Python代码)。这个扩展在没有服务器扩展的情况下也能工作,但有一个主要缺点:当向GitHub发出未经认证的请求时(我们必须这样做以获取仓库数据),GitHub对我们可以发出的请求数量施加了相当严格的速率限制。因此,您可能在几分钟的工作后就会达到这个限制。然后您将不得不等待最多一小时才能重新获得访问权限。

因此,我们建议您花时间和精力同时设置服务器扩展和实验室扩展,这将允许您访问更高的速率限制。这个过程在安装部分有描述。

先决条件

  • JupyterLab > 3.0
  • 服务器扩展需要GitHub账户

安装

如上所述,这个扩展既有服务器扩展,也有实验室扩展。从PyPI安装时,默认会安装这两个扩展,但如果您使用JupyterLab的扩展管理器,可能只安装了实验室扩展。

我们建议完成以下步骤以避免受到速率限制。服务器扩展的目的是添加您需要从https://github.com/settings/developers 获取的GitHub凭据,然后代理您对GitHub的请求。

对于3版本以前的JupyterLab,请参阅2.x分支上的说明。

1. 安装服务器和预构建的实验室扩展

JupyterLab 4.x

要安装服务器扩展和(预构建的)实验室扩展,在终端中输入以下命令:

pip install jupyterlab-github

JupyterLab 3.x

我们需要将扩展版本固定为3.0.1以使其在JupyterLab 3.x上工作。

pip install 'jupyterlab-github==3.0.1'

重启JupyterLab后,扩展应该能够工作,您可以亲身体验被速率限制的乐趣!

2. 从GitHub获取凭据

从GitHub获取凭据有两种方法: (1) 您可以获取访问令牌,(2) 您可以注册OAuth应用。 不推荐第二种方法,将在未来版本中移除。

获取访问令牌(推荐

您可以按照以下步骤获取访问令牌:

  1. 验证您的GitHub电子邮件地址。
  2. 进入GitHub上的账户设置,从左侧面板选择"Developer Settings"。
  3. 在左侧,选择"Personal access tokens"。
  4. 点击"Generate new token"按钮,并输入您的密码。
  5. 给令牌一个描述,并勾选"repo"范围复选框。
  6. 点击"Generate token"。
  7. 您将得到一个字符串,这就是您的访问令牌。 请记住,这个令牌实际上是您GitHub账户的密码。 切勿在网上分享或将令牌存入版本控制系统中,因为他人可以利用它访问您在GitHub上的所有数据。

设置OAuth应用程序(已弃用)

这种与GitHub认证的方法已被弃用,将在未来的版本中移除。 新用户应使用访问令牌方法。 您可以按照以下步骤在GitHub上注册OAuth应用程序:

  1. 登录您的GitHub账户。
  2. 前往https://github.com/settings/developers,并选择左侧的"OAuth Apps"选项卡。
  3. 点击"New OAuth App"按钮。
  4. 在表单中填写名称、主页URL、描述和回调URL。 这个扩展实际上并不使用OAuth,所以这些值实际上并不重要, 您只需要输入它们来注册应用程序。
  5. 点击"Register application"按钮。
  6. 您应该会被带到一个显示新应用程序信息的新页面。 如果您看到显示"Client ID"和"Client Secret"的字段,恭喜您! 这些就是我们需要的字符串,您已成功设置了应用程序。

需要注意的是,"Client Secret"字符串顾名思义是一个秘密。 切勿在网上分享这个值,因为他人可能会利用它在GitHub上冒充您。

3. 启用和配置服务器扩展

如果您使用pip安装,服务器扩展将在新的JupyterLab安装中默认启用。 如果您使用JupyterLab中的扩展管理器,请卸载扩展并按照第(1)点的说明重新安装。

通过以下命令确认服务器扩展已安装并启用:

jupyter server extension list

您应该看到以下内容:

- Validating jupyterlab_github...
     jupyterlab_github 4.0.0 OK

在一些较旧的安装(例如旧版JupyterHub)中使用jupyter notebook服务器而不是新的jupyter-server,扩展需要显示在旧的serverextensions列表中(注意:server和extension之间没有空格):

jupyter serverextension list

如果扩展未启用,请运行:

jupyter server extension enable jupyterlab_github

或者如果使用旧版notebook服务器:

jupyter serverextension enable jupyterlab_github

现在您需要将从GitHub获得的凭证添加到服务器配置文件中。生成配置文件的说明可以在这里找到。 一旦您找到了这个文件,请在其中添加以下行:

c.GitHubConfig.access_token = '< YOUR_ACCESS_TOKEN >'

其中"< YOUR_ACCESS_TOKEN >"是您上面获得的字符串值。 如果您生成了OAuth应用程序,请输入以下内容:

c.GitHubConfig.client_id = '< YOUR_CLIENT_ID >'
c.GitHubConfig.client_secret = '< YOUR_CLIENT_SECRET >'

其中"< YOUR_CLIENT_ID >"和"< YOUR_CLIENT_SECRET >"是您上面获得的应用程序值。

这样,您就完成了!启动JupyterLab并在左侧寻找GitHub选项卡!

自定义

您可以设置插件在启动时显示特定的仓库。 在设置菜单中打开"高级设置"编辑器, 在GitHub设置下添加

{
  "defaultRepo": "owner/repository"
}

其中owner是GitHub用户/组织, repository是您想要打开的仓库名称。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号