python中需要引用文件名称在哪

python中需要引用文件名称在哪,第1张

第一种:os.listdir

os.listdir() 方法用于返回指定的目录下包含的文件或子目录的名字的列表。这个列表以字母顺序。其得到的是仅当前路径下的文件名,不包括子目录中的文件,如果需要得到所有文件需要递归。 它也不包括 '.' 和 '..' 即使它在目兆族录中。

语法格式为:os.listdir(path)

举例:def list_dir(file_dir):

'''

通过 listdir 得到的是仅当前路径下的文件名,不包括子目录中的文件,如果需要得到所有文件需要递归

'''

print'\族尘弊n\n<><><><><><>listdir <><><><><><>'

print "current dir : {0}".format(file_dir)

dir_list = os.listdir(file_dir)

for cur_file in dir_list:

# 获取文件的绝对路径

path = os.path.join(file_dir, cur_file)

if os.path.isfile(path): # 判断是否是文件还是目录需要用绝对路径

print "{0} : is file!".format(cur_file)

if os.path.isdir(path):

print "{0} : is dir!".format(cur_file)

list_dir(path) # 递归子目录

第兄桐二种:os.walk

os.walk() 方法用于通过在目录树中游走输出在目录中的文件名,向上或者向下。是一个简单易用的文件、目录遍历器,可以帮助我们高效的处理文件、目录方面的事情。

语法格式为:os.walk(top[, topdown=True[, οnerrοr=None[, followlinks=False]]])

方法参数说明:top:要遍历的目录的路径

topdown:可选,如果为 True,则优先遍历 top 目录,以及 top 目录下的每一个子目录,否则优先遍历 top 的子目录,默认为 True

onerror: 可选, 需要一个 callable 对象,当 walk 异常时调用

followlinks:可选, 如果为 True,则会遍历目录下的快捷方式(linux 下是 symbolic link)实际所指的目录,默认为 False

args:包含那些没有 '-' 或 '--' 的参数列表

返回值: 三元组 (root, dirs, files)

root :所指的是当前正在遍历的目录的地址

dirs :当前文件夹中所有目录名字的 list (不包括子目录)

files :当前文件夹中所有的文件 (不包括子目录中的文件)

举例:def work_dir(file_dir):

print'\n\n<><><><><>work dir <><><><><>'

for root, dirs, files in os.walk(file_dir):

print'\n========================================'

print "root : {0}".format(root)

print "dirs : {0}".format(dirs)

print "files : {0}".format(files)

for file in files:

try:

print'-----------------------------------'

file_name = os.path.splitext(file)[0]

file_suffix = os.path.splitext(file)[1]

file_path = os.path.join(root, file)

file_abs_path = os.path.abspath(file)

file_parent = os.path.dirname(file_path)

print "file : {0}".format(file)

print "file_name : {0}".format(file_name)

print "file_suffix : {0}".format(file_suffix)

print "file_path : {0}".format(file_path)

print "file_abs_path : {0}".format(file_abs_path)

print "file_parent : {0}".format(file_parent)

except Exception, e:

print "Exception", e

找到文件目录,对于Python初学者来说算是一个简单 *** 作了,希望本文能对Python小白有所帮助。

可以直接通过pycharm来修改import的塌袭路径,具体pycharm版本不大衫改一样,对应按钮位置不一样,滚判因此仅以文字说明。

file->Settings(Ctrl+Shift+s)->Project Setting->Project Interpreter->选择本机的python版本->Interpreter Path->添加。

如果在tests下有文件夹test2,其下有文件c.py。要引用c文件的c2

在你的main.py里面加入:

from test2.c import c2

路径是以添加的路径的相对路径。

一、Python查找模块的路径

运行Python应用或引用Python模块,Python解释器要有一个查找的过程。可以通过设置一个环境变量PYTHONPATH为Python增加一个搜索路径,以方便查找到相关Python模块(不同的 *** 作系统环境变量的设置稍有不同,默认以下都是WIndows环境),这与众多应用程序需要设置一个系统环境变量的道理是一样的。在命令行中可以通过以下命令设置:

C:\Users\Administrator>set PYTHONPATH=E:/Project/Python/ModuleAndPackage/

进入Python环境后可以,通过Python的sys.path属性获得当前搜索路径的配置,可以看到之前我们设置的路径已经在当前搜索路径中了。

C:\Users\Administrator>pythonPython 2.7.11 (v2.7.11:6d1b6a68f775, Dec 5 2015, 20:32:19) [MSC v.1500 32 bit (Intel)] on win32Type "help", "copyright", "credits" or "license" for more information.>>>import sys>>>sys.path['', 'E:\\Project\\Python\\ModuleAndPackage', 'C:\\Windows\\system32\\python27.zip', 'C:\\Python\\DLLs', 'C:\\Python\\lib', 'C:\\Python\\lib\\plat-win', 'C:\\Python\\lib\\lib-tk', 'C:\\Python', 'C:\\Python\\lib\\site-packages']>>>

也可以通过sys模块的append方法在Python环境中增加搜索路径。

>>>sys.path.append("E:\\Project\\Python\\ModuleAndPackage2")>>>sys.path['', 'E:\\Project\\Python\\ModuleAndPackage'穗链, 'C:\\Windows\\system32\\python27.zip', 'C:\\Python\\DLLs', 'C:\\Python\\lib', 'C:\\Python\\lib\\plat-win', 'C:\\Python\\lib\\lib-tk', 'C:\\Python', 'C:\\Python\\lib\\site-packages', 'E:\\Project\\Python\\ModuleAndPackage2']>>>

二、Python中的模块和包

前面已经提到每个.py文件都是可以认为是一个Python模块,.py文件中可以包含类、方法、猜族孙变量和常量(Python还没有严格意义上的常量,只是约定大写的变量作为常量),文件内也可以直接写所有的逻辑语句并在加载时从上之下直接执行,这与其他解释型语言是类似的。例如我们选择在文件夹ModuleAndPackage中创建一个文本文件person.py文件即创建了一个简单的Python模块,其内容如下:

# -*- coding: utf-8 -*-ID = 1name = "This person"print namedef say(something):print name,'says', something

那么接下来我们就可以在Python环境中执行person.py。我们可以直接像执行一个批处理文件那穗灶样执行person.py,在cmd命令行输入:

Python E:/Project/Python/ModuleAndPackage/person.py

本质上任何一个Python应用的入口模块都是这样被执行的(像C#和Java中的main函数),但是引用一个模块,就要建立运行它的上下文环境。我们先设置一个环境变量PYTHONPATH,以便Python解释器找到person.py模块,然后import person模块,即可访问其中的方法或变量。

C:\Users\Administrator>pythonPython 2.7.11 (v2.7.11:6d1b6a68f775, Dec 5 2015, 20:32:19) [MSC v.1500 32 bit (Intel)] on win32Type "help", "copyright", "credits" or "license" for more information.>>>import personThis person>>>person.say("hello")This person says hello>>>print person.nameThis person>>>

Python需要去某些固定的路径下去查找Python模块,上面我们设置在ModuleAndPackage中查找。但是这些路径下也是有目录层次的,Python是如何查找子目录中的模块呢?特别是引用第三方包时,我们也需要知道一定的层次关系。实际上,Python通过目录和文件构建包结构,并且包是层层嵌套的,和目录层层嵌套是一样的,这样就构成了包内的访问路径(或者命名空间,也可以说Python应用的命名空间与其目录和文件结构是对应了,似乎缺少了一些灵活,但也更简单)。例如我们在ModuleAndPackage文件夹下,创建一个文件夹animal,里面创建一个文本文件pet.py,其内容如下:

# -*- coding: utf-8 -*-ID = 2name = "This pet"print namedef run(somewhere):print name,'runs', somewhere

那么如何引用pet.py这个模块呢?按照Python的约定,需要在animal文件夹中创建名为__init__.py的空文本文件,以标识animal文件夹是一个包。倘若animal文件夹内还有文件夹作为包,也必须包含__init__.py文件。这样就层层标识了访问的路径。

>>>import animal.petThis pet>>>print animal.pet.nameThis pet>>>animal.pet.run("everywhere")This pet runs everywhere>>>

或者使用from关键字直接导入模块内的属性或方法:

>>>from animal.pet import name,run>>>print nameThis pet>>>run("everywhere")This pet runs everywhere>>>

三、Python模块间引用

简答来说,只要Python模块在其执行环境配置的搜索路径中,并且其所在位置是包结构的一部分,那么我们就可以引用该模块。上文已经提供了模块引用的基本示例。只不过模块间引用时import语句是写在模块文件中,我们修改person.py模块的代码。

1、from、import和as

# -*- coding: utf-8 -*-ID = 1name = "This person"print namedef say(something):print name,'says', somethingfrom animal.pet import name as pet_name, run as pet_rundef have():print name,'has', pet_name

import语句可以写在文档中的任何位置,甚至if语句中,以便更好的控制模块引用。还可以通过as语句,使用另一个变量名进行引用,以避免变量名冲突。>>>import personThis personThis pet>>>print person.nameThis person>>>print person.pet_nameThis pet>>>person.have()This person has This pet>>>


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12270665.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存