python 引用

python 引用,第1张

python引用有哪些?来和我一起解读一下吧~

python不允许程序员用传值和传引用,可以选择选用“传对象引用”的方式,这种方式等同于将传值和传引用综合起来,如果函数收到的是一个可变对象的引用,就能修改对象的原始值,相当于通过“传引用”来传递对象,如果函数收到的是一个不可变对象的引用,就不能直接修改原始对象,相当于通过“传值’来传递对象。

python引用主要有:不可变数据引用和可变数据引用,其中不可变数据引用包括:字符串String、浮点型Float、元祖Tuple。

1、字符串String

#1.字符串引用 a='1234' b=a a='hello' print('a:',a) #a:hello print('b:',b)  #b:1234 #查看内存地址 print('a的内存地址是:',id(a)) print('a的内存地址是:',id(b)) 结果是: a: hellob: 1234a的内存地址是: 1651738050720a的内存地址是: 1651737219456 分析:b的值指向a的值。python开辟了新的内存空间给b,所以a和b的内存地址不一样。

2、浮点型Float

#2.浮点型引用 x=3.14 y=x x=9.88 print('x:',x) print('y:',y) print('x的内存地址是:',id(x)) print('y的内存地址是:',id(y)) 结果是: x: 9.88y: 3.14x的内存地址是: 2578075558248y的内存地址是: 2578075558008

3、元祖Tuple

元祖虽然是序列,且包含多个元素,但是不支持原处修改,如tuple[1]=1是非法的。#3.元祖引用 t1=(1,2,3,4,5) t2=t1 t1=('tuple','hello') print('t1:',t1) print('t2:',t2) print('t1的内存地址是:',id(t1)) print('t2的内存地址是:',id(t2)) 结果是: t修改后为: (1, 2, 3, ['x', 'a', 'D', 'b']) 可变数据引用包括:列表引用、字典引用、函数的传递引用

1、列表引用

#4 列表的可变引用 list1=[1,2,3,4,5] list2=list1 list1[3]='list' print('list1=====%s'%list1) print('list2=====%s'%list2) print('list1的内存地址是:',id(list1)) print('list2的内存地址是:',id(list2)) 结果是: list1=====[1, 2, 3, 'list', 5]list2=====[1, 2, 3, 'list', 5]list1的内存地址是: 2769992249864list2的内存地址是: 2769992249864

2、函数的传递引用

def eggs(someParameter):     someParameter.append('hello list') spam=[1,2,3,4] eggs(spam) print(spam) 结果是: [1, 2, 3, 4, 'hello list']

3、字典引用 #5 字典的引用 a={'name':'Cathy','age':'27','job':'coder'} b=a a['age']='30' b['name']='Bob' print('a======%s'%a) print('b======%s'%b) print('a的内存地址是:', id(a)) print('b的内存地址是:', id(b)) 结果是: a======{'name': 'Bob', 'age': '30', 'job': 'coder'} b======{'name': 'Bob', 'age': '30', 'job': 'coder'} a的内存地址是: 2510825602792 b的内存地址是: 2510825602792

第一种: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小白有所帮助。


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

原文地址:https://54852.com/tougao/11439789.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存