python 代码如下:
import osimport loggingpath = 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:
NameError: name '__file__' is not defined.而明确路径后没有出错(logging.txt中调试信息正常):
path = 'F:\\Python_Test'网上找了些资料,有说是:“内置模块不存在__file__属性”。尤其是在使用py2exe时,也同样有问题。
自己找了些对于获取路径的资料:
# -*- coding: utf-8 -*-import osimport sysprint '当前所运行脚本的目录:'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])运行结果:
另附资料:
有时需要获取Python脚本的当前目录,下边是一个实现的方案。
Google了一下,网上也有其它实现办法,但是如果使用py2exe编译后,或者更改当前工作目录后会出现不同结果,这种方案没有这个问题。
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()
谁还有好的解决获取路径的方法可告知,谢谢!