python 遇到NameError: name '__file__' is not defi...

python 代码以下: python

import os
import logging

path = os.path.dirname(__file__)
LOG_FILENAMW = path+'\\logging.txt'
    logging.basicConfig(filename = LOG_FILENAMW, level=logging.DEBUG)
    logging.debug('This message should go to the log file.')

在logging.txt文件中查看发现有个error: spa

NameError: name '__file__' is not defined.
而明确路径后没有出错(logging.txt中调试信息正常):
path = 'F:\\Python_Test'
网上找了些资料,有说是:“内置模块不存在__file__属性”。尤为是在使用py2exe时,也一样有问题。

本身找了些对于获取路径的资料: debug

# -*- coding: utf-8 -*-
import os
import sys


print '当前所运行脚本的目录:'
print 'os.getcwd():\n',\
        os.getcwd()
print '\n当前文件的绝对路径:'
print 'sys.path[0]:\n',\
        sys.path[0]
print '\nos.path.dirname(os.path.abspath( __file__ )):\n',\
		os.path.dirname(os.path.abspath( __file__ ))
print '\nos.path.split(os.path.realpath(__file__))[0]:\n',\
        os.path.split(os.path.realpath(__file__))[0]
print '\nsys.argv[0]:',\
        sys.argv[0]
print '\nos.path.realpath( sys.argv[0] ) :\n',\
        os.path.realpath( sys.argv[0] ) 
print '\nos.path.split( os.path.realpath( sys.argv[0] ) )[0]:\n',\
        os.path.split( os.path.realpath( sys.argv[0] ) )[0]
print '\nos.path.split( os.path.realpath( sys.argv[0] ) )[1]:\n',\
        os.path.split( os.path.realpath( sys.argv[0] ) )[1]
print '\nos.path.split(sys.argv[0]):\n',\
        os.path.split(sys.argv[0])
运行结果:

另附资料:http://hi.baidu.com/nivrrex/item/a0d47c0f4bd9fdce905718a0 调试

有时须要获取Python脚本的当前目录,下边是一个实现的方案。 code

Google了一下,网上也有其它实现办法,可是若是使用py2exe编译后,或者更改当前工做目录后会出现不一样结果,这种方案没有这个问题。 utf-8

import sys,os
#获取脚本文件的当前路径
def cur_file_dir():
    #获取脚本路径
    path = sys.path[0]
    #判断为脚本文件仍是py2exe编译后的文件,若是是脚本文件,则返回的是脚本的目录,若是是py2exe编译后的文件,则返回的是编译后的文件路径
    if os.path.isdir(path):
        return path
    elif os.path.isfile(path):
        return os.path.dirname(path)
#打印结果
print cur_file_dir()

谁还有好的解决获取路径的方法可告知,谢谢! get

相关文章
相关标签/搜索