V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
mxmai
V2EX  ›  Python

pycharm 运行时执行了两次

  •  
  •   mxmai · 2017-12-20 23:25:49 +08:00 · 2990 次点击
    这是一个创建于 2559 天前的主题,其中的信息可能已经有所发展或是发生改变。

    RT,PyCharm版本号是Community Edition 2017.2.4 https://wx2.sinaimg.cn/mw690/62f40e5bgy1fmnnbkf91ij20qn0goqmj.jpg

    以下是脚本

    # coding: utf-8
    import numpy as np
    import pandas as pd
    from tempfile import NamedTemporaryFile
    
    np.random.seed(42)
    a = np.random.randn(365, 4)
    
    # tmpf = NamedTemporaryFile()
    tmpf = './data/t.csv'
    store = pd.io.pytables.HDFStore(tmpf)
    print store
    
    df = pd.DataFrame(a)
    store['df'] = df
    print store
    
    print "Get", store.get('df').shape
    print "Lookup", store['df'].shape
    print "Dotted", store.df.shape
    
    del store['df']
    print "After del\n", store
    
    print "Before close", store.is_open
    store.close()
    print "After close", store.is_open
    
    df.to_hdf(tmpf, 'data', format='table')
    print pd.read_hdf(tmpf, 'data', where=['index>363'])
    

    以下是运行的结果,之前还只是以为重复打印。刚开始t.csv文件是不存在的,所以 HDFStore 的结果是Empty。但是查看运行结果发现第二次的文件结果不为空,由此可以程序又运行了一次。

    # 第一次运行
    C:\APPS\Anaconda\python.exe D:/DATA/DEV/python/py.py
    <class 'pandas.io.pytables.HDFStore'>
    File path: ./data/t.csv
    Empty    #结果为空
    <class 'pandas.io.pytables.HDFStore'>
    File path: ./data/t.csv
    /df            frame        (shape->[365,4])
    Get (365, 4)
    Lookup (365, 4)
    Dotted (365, 4)
    After del
    <class 'pandas.io.pytables.HDFStore'>
    File path: ./data/t.csv
    Empty
    Before close True
    After close False
                0         1         2         3
    364  0.753342  0.381158  1.289753  0.673181
    # 第二次运行
    <class 'pandas.io.pytables.HDFStore'>
    File path: ./data/t.csv
    # 文件结果不为空,由此可以程序又运行了一次
    /data            frame_table  (typ->appendable,nrows->365,ncols->4,indexers->[index]) 
    <class 'pandas.io.pytables.HDFStore'>
    File path: ./data/t.csv
    /data            frame_table  (typ->appendable,nrows->365,ncols->4,indexers->[index])
    /df              frame        (shape->[365,4])                                       
    Get (365, 4)
    Lookup (365, 4)
    Dotted (365, 4)
    After del
    <class 'pandas.io.pytables.HDFStore'>
    File path: ./data/t.csv
    /data            frame_table  (typ->appendable,nrows->365,ncols->4,indexers->[index])
    Before close True
    After close False
                0         1         2         3
    364  0.753342  0.381158  1.289753  0.673181
    
    Process finished with exit code 0
    

    请问是什么原因?

    2 条回复    2017-12-21 14:01:51 +08:00
    scriptB0y
        1
    scriptB0y  
       2017-12-21 11:16:11 +08:00
    提问的时候提供一个最小的重现例子
    mxmai
        2
    mxmai  
    OP
       2017-12-21 14:01:51 +08:00
    @scriptB0y 上面的代码以及运行结果就是例子。但是我将同样的代码拷到另台机器上的`pycharm`上运行却没有重复运行。所以我也不知道是什么原因了。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5401 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 101ms · UTC 07:32 · PVG 15:32 · LAX 23:32 · JFK 02:32
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.