首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >私人jupyter笔记本

私人jupyter笔记本
EN

Stack Overflow用户
提问于 2022-10-19 13:10:22
回答 2查看 34关注 0票数 0

是否有办法使其他人无法使用更漂亮的笔记本内容?我想和其他人分享笔记本,这样它就可以执行必要的操作,但是用户看不到里面的代码。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-10-19 13:18:44

如果您将执行操作的代码保存到一个格式适当的.py文件中,并从该文件中导入您希望执行的调用--您可以将其与笔记本一起分发,并封装您的用户界面(笔记本),而不是逻辑( .py文件中的代码)。

例如,在您的笔记本中,您有一个功能:

代码语言:javascript
复制
def do_things(df):
    # do all the things
    # many lines of logic embedded in code
    ...
    return results

为了避免向用户显示该代码,请将其保存在一个名为privatethings.py的python文件中,并在笔记本开始时导入它。

代码语言:javascript
复制
import privatethings as pv

只要它存在于与您的笔记本相同的文件夹中,它将被导入,并允许您以一行代码块的形式执行操作。

代码语言:javascript
复制
pv.do_things(df)

一个适当的封闭用户可能会发现他们可以编辑.py文件,所以如果他们想让进程按照您的设计工作,您就必须告诉他们不要这样做。但那将是他们的守望。

编辑

在下面的对话中,从远程资源获取代码的一种方法(可能是不确定的)可能是将其保存为一些脱机资源(例如在url中,或者在一个加密的文本文件中),这些资源可以由笔记本来获取。

然后,使用编译函数,可以将python源代码编译成exec-able形式,使您能够访问从(相对)模糊的源代码导入的函数。

下面是一个例子:

文件privatethings.py:

代码语言:javascript
复制
def secret(string):
    return [s for s in string][::-1]

将此文件保存在http://myloc.com/privatethings.py

使用请求:

代码语言:javascript
复制
import requests

url = 'http://myloc.com/privatethings.py'
r = requests.get(url)
source = r.text
code = compile(source, '<string>', 'exec')
exec(code)    # From here on, all functions in privatethings.py are available in this environment
secret("test")

>>> "tset"

当然,执行这样的代码在信任方面是有问题的(在某些情况下可能会被认为是不道德的),但是由于下面讨论了它,所以上面是如何实现这样一件事情的最起码的例子。

票数 0
EN

Stack Overflow用户

发布于 2022-10-19 13:15:51

这是不可能的方式,你说,但你可以保存输出的笔记本。您所需要做的就是在获得输出后执行块并删除代码。通过这种方式,您可以共享输出而不共享代码。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74125951

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档