http://blog.51cto.com/xpleaf/1736956
http://blog.csdn.net/u011760056/article/details/46969883
1. Notes.
os.path.dirname(__file__)返回脚本的路径,但是需要注意一下几点:
1、必须是实际存在的.py文件,如果在命令行执行,则会引发异常NameError: name '__file__' is not defined
2、在运行的时候如果输入完整的执行的路径,则返回.py文件的全路径如:
python c:/test/test.py 则返回路径 c:/test ,如果是python test.py 则返回空
3、结合os.path.abspath用,效果会好,如果大家看过一些python架构的代码的话,会发现经常有这样的组合
os.path.dirname(os.path.abspath(__file__)),os.path.abspath(__file__)返回的是.py文件的绝对路径
这就是os.path.dirname(__file__)的用法,其主要总结起来有:
-- 不要以命令行的形式来进行os.path.dirname(__file__)这种形式来使用这个函数
-- 结合os.path.abspath()使用
2.测试
先看一下我当前环境下的两个python脚本文件:
1
2
3
4
|
xpleaf@leaf:~ /Source_Code $ pwd /home/xpleaf/Source_Code xpleaf@leaf:~ /Source_Code $ ls hello.py test_os_path.py |
hello.py里面没有内容,待会用来做测试,主要来看一下test_os_path.py的代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
import os path1 = os.path.dirname(__file__) print 'The path1 is:' , path1 path2 = os.path.abspath(path1) print 'The path2 is:' , path2 path3 = os.path.join(path2, 'hello.py' ) print 'The path3 is:' , path3 |
通过看下面的两种执行方式,我们来深刻理解上面三个方法的作用:
(1)以相对路径的方式来执行test_os_path.py
1
2
3
4
|
xpleaf@leaf:~ /Source_Code $ python test_os_path.py The path1 is: The path2 is: /home/xpleaf/Source_Code The path3 is: /home/xpleaf/Source_Code/hello .py |
(2)以绝对路径的方式来执行test_os_path.py
1
2
3
4
|
xpleaf@leaf:~ /Source_Code $ python /home/xpleaf/Source_Code/test_os_path .py The path1 is: /home/xpleaf/Source_Code The path2 is: /home/xpleaf/Source_Code The path3 is: /home/xpleaf/Source_Code/hello .py |
通过上面两种执行方式的输出,就很容易看出三者的作用了。那在实际开发中,有什么用呢?
3.在实际开发中使用os.path
在实际开发中,我们肯定是要设定一个某些文件的路径的,比如在Web开发中,对于模板和静态文件的路径设定等,其实如果你用过Django或者Flask,应该就可以经常看到在它们的配置文件中,有os.path的出现,一般这样来用:
(1)首先获得当前文件(比如配置文件)所在的路径
1
|
basedir = os.path.abspath(os.path.dirname(__file__)) |
(2)设定某个文件的绝对路径
1
|
static_file_path = os.path.join(basedir, 'index.html' ) |