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

相關文章
相關標籤/搜索