提问者:小点点

在conda环境中创建jupyter notebook可以理解的python模块


我已经安装了anaconda,并使用conda创建了一个环境。除了在env中使用pip安装的zenlog之外,所有包都是使用conda安装的。

我有两个模块(.py文件)是按以下方式编写的,它们都有我下面描述的错误。

模块与用于创建和激活此环境的环境文件一起存储在/Documents/python/project目录中。

使用conda list可以看到所有库或包,并正确导入。当我尝试创建logtextfile类的对象时,我的简单模块失败了。

当我从我的日志模块(我称之为mylog.py)创建对象时,我得到了错误:`

NameError:未定义名称“logtextfile”

当我在与我的mylog.py模块相同的目录中创建一个jupyter笔记本并按如下方式导入时,会出现此错误:

import mylog  # A simple module to log a message to a text file.

但当我将mylog模块的类和函数复制到测试单元中时。ipynb jupyter笔记本,并创建一个类的对象,它可以毫无问题地工作。

当logging类的对象位于模块(一个单独的.py文件)中时,与jupyter笔记本单元相比,我在创建该对象时有什么不同之处?

“我的项目”文件夹的文件结构为:

Folder: /Documents/python/project目录

文件测试。ipynb

文件mylog。派克

...

我的模块是:

import datetime
import os

class logtextfile(object):   
    def __init__(self, name):
        self.name = name

    def __str__(self):
        return "{} ".format(self.__class__.__name__)

    def write(self,**kwargs):
        """Writes a log message to a user specified file which indicates the action takes and if it was successful"""
        self.file = kwargs.get('file',"log.txt")
        self.loglevel = kwargs.get('loglevel',"critical")
        self.logmessage = kwargs.get('logmessage',"error")
        self.success = kwargs.get('success',False)
        self.class_name = kwargs.get('class',str("{}".format(self.__class__.__name__)))
        self.output = ", ".join([str(datetime.datetime.now().replace(second=0,microsecond=0)),self.class_name,str(self.logmessage),str(self.success),str("\n")])

        for key, value in kwargs.items():
            setattr(self,key,value)

        f = open(str(self.file),"a")
        f.write(self.output)
        f.close()

    def now(self, filename, openas, data):
        """Creates a log file with todays date and time"""
        fmt='%Y-%m-%d-%H-%M-%S_{fname}'
        fn = datetime.datetime.now().strftime(fmt).format(fname=filename)
        f = open(str(fn),openas)
        f.write(data + "\n")
        f.close()

如果有人想尝试在jupyter笔记本单元中创建日志类的对象,并从mylog导入它,那么这里有一个我的conda环境的副本。py文件。

要求:

  • 已安装蟒蛇
<pre>
  <code>
name: stocks_library
channels:
- anaconda-fusion
- defaults
dependencies:
- appnope=0.1.0=py35_0
- beautifulsoup4=4.5.3=py35_0
- blaze=0.10.1=py35_0
- bleach=1.5.0=py35_0
- bokeh=0.12.5=py35_0
- chest=0.2.3=py35_0
- click=6.7=py35_0
- cloudpickle=0.2.2=py35_0
- cytoolz=0.8.2=py35_0
- dask=0.13.0=py35_0
- datashape=0.5.4=py35_0
- decorator=4.0.11=py35_0
- entrypoints=0.2.2=py35_1
- flask=0.12.1=py35_0
- flask-cors=3.0.2=py35_0
- h5py=2.6.0=np110py35_0
- hdf5=1.8.15.1=2
- heapdict=1.0.0=py35_1
- html5lib=0.999=py35_0
- icu=54.1=0
- ipykernel=4.6.1=py35_0
- ipython=6.0.0=py35_0
- ipython_genutils=0.2.0=py35_0
- ipywidgets=6.0.0=py35_0
- itsdangerous=0.24=py35_0
- jinja2=2.9.6=py35_0
- jsonschema=2.6.0=py35_0
- jupyter=1.0.0=py35_3
- jupyter_client=5.0.1=py35_0
- jupyter_console=5.1.0=py35_0
- jupyter_core=4.3.0=py35_0
- libiconv=1.14=0
- libpq=9.5.4=0
- libxml2=2.9.4=0
- libxslt=1.1.29=0
- llvmlite=0.11.0=py35_0
- locket=0.2.0=py35_1
- lxml=3.7.3=py35_0
- markupsafe=0.23=py35_2
- mistune=0.7.4=py35_0
- mkl=11.1=np110py35_p1
- mkl-rt=11.1=p0
- mkl-service=1.1.0=py35_p0
- multipledispatch=0.4.9=py35_0
- mysql-connector-python=2.0.4=py35_0
- nbconvert=5.1.1=py35_0
- nbformat=4.3.0=py35_0
- networkx=1.11=py35_0
- notebook=5.0.0=py35_0
- numba=0.26.0=np110py35_0
- numexpr=2.4.6=np110py35_0
- numpy=1.10.2=py35_p0
- odo=0.5.0=py35_1
- openssl=1.0.2k=1
- pandas=0.18.1=np110py35_0
- pandas-datareader=0.2.1=py35_0
- pandasql=0.7.3=py35_0
- pandocfilters=1.4.1=py35_0
- partd=0.3.7=py35_0
- path.py=10.3.1=py35_0
- pexpect=4.2.1=py35_0
- pickleshare=0.7.4=py35_0
- pip=9.0.1=py35_1
- postgresql=9.5.4=0
- prompt_toolkit=1.0.14=py35_0
- psutil=5.2.2=py35_0
- psycopg2=2.7.1=py35_0
- ptyprocess=0.5.1=py35_0
- pygments=2.2.0=py35_0
- pymysql=0.7.9=py35_0
- pyqt=5.6.0=py35_2
- pytables=3.2.2=np110py35_0
- python=3.5.3=1
- python-dateutil=2.6.0=py35_0
- pytz=2017.2=py35_0
- pyyaml=3.12=py35_0
- pyzmq=16.0.2=py35_0
- qt=5.6.2=0
- qtconsole=4.3.0=py35_0
- readline=6.2=2
- requests=2.13.0=py35_0
- requests-file=1.4.1=py35_0
- scikit-learn=0.17=np110py35_p1
- scipy=0.16.1=np110py35_p0
- setuptools=27.2.0=py35_0
- simplegeneric=0.8.1=py35_1
- sip=4.18=py35_0
- six=1.10.0=py35_0
- sqlalchemy=1.1.9=py35_0
- sqlite=3.13.0=0
- terminado=0.6=py35_0
- testpath=0.3=py35_0
- tk=8.5.18=0
- toolz=0.8.2=py35_0
- tornado=4.4.2=py35_0
- traitlets=4.3.2=py35_0
- wcwidth=0.1.7=py35_0
- werkzeug=0.12.1=py35_0
- wheel=0.29.0=py35_0
- widgetsnbextension=2.0.0=py35_0
- xz=5.2.2=1
- yaml=0.1.6=0
- zlib=1.2.8=3
- pip:
  - ipython-genutils==0.2.0
  - jupyter-client==5.0.1
  - jupyter-console==5.1.0
  - jupyter-core==4.3.0
  - prompt-toolkit==1.0.14
  - tables==3.2.2
prefix: /Users/joshua/miniconda3/envs/stocks_library
  </code>
</pre>

共1个答案

匿名用户

在这里,我在试图创建对象时错误地引用了该模块。

其中,当我尝试logger=logtextfile(“myfile”)

我应该写:

import mylog
logger = mylog.logtextfile("myfile")
logger.write(logmessage="mymessage",success=True)
print("log complete")