python获取文件权限linux中,如何使用python获取指定文件的权限

python获取文件权限linux中,如何使用python获取指定文件的权限,第1张

[root@st-upgrade ~]# python

Python 2.6.5 (r265:79063, Nov 12 2010, 00:45:29)

[GCC 4.4.4 20100525 (Red Hat 4.4.4-5)] on linux2

Type "help", "copyright", "credits" or "license" for more information.

>>>import os

>>>os.stat('/home').st_mode

16877

>>>oct(os.stat('/home').st_mode)

'040755'

755就是/home的权限,切个片oct(os.stat('/home').st_mode)[3:],就可以了

在磁盘上读写文件之前,必须先打开这个文件。打开文件就需要提供文件的路径。

在与Python程序同一个目录下,我们有一个名为 pi.txt 的文件,它的内容如下:

现在使用Python来打开和关闭它:

执行此程序不会有任何输出,这表示着打开和关闭文件都得到了正确执行。

可以看到,使用 open() 函数打开文件,参数为文件名(或文件路径);该函数会返回一个文件句柄,文件句柄并不会实际保存文件的内容,而是代表着一种 *** 作,在上面的例子中,文件句柄被赋值给变量 fhand 。

打开文件后,程序具有读(默认)该文件的权限。

最后,使用文件句柄的 close() 方法关闭文件。这非常重要,因为使用完而没有关闭的文件会占用内存或造成安全问题。

如果Python找不到该文件,则会返回错误,比如下面这样:

Python提示我们没有相应的文件或者目录: 'pii.txt'。

打开文件后就可以对文件进行 *** 作:

fhand.read() 方法将文件内容作为一个字符串返回。

文件中的每一行末尾使用换行符 \n 表示换行,例子中方法 rstrip() 去掉文本中的换行符,然后输出。

程序的运行效果如下:

如果在文件关闭之前程序发生BUG意外退出,则文件不会关闭,为了避免此类事件的发生,可以使用 with 语句:

with 语句的特点是即便在 *** 作文件时发生错误,文件也会自动被清理。

fhand.read() 虽然可以读取文本内容,但是当我们想要逐行处理文件内容,或者文件很大而无法一次性加载进内存的时候,就不适用了。

可以使用 for 语句逐行处理文件内容:

本程序中将文件名保存在变量 filename 中。

打开文件后,使用 for 语句按行读取文件内容。例子中,每次循环依次取一行文本以字符串的格式保存在变量 line 中,每次循环中变量 count 自增1。

这个程序的作用是,打开程序所在目录的 when_old.txt 文件,然后统计行数,并输出结果。

when_old.txt 文件的内容是:

可以使用其他方法 *** 作字符串 line :

程序将以 'And' 开头的行打印出来。

打开文件后,默认的权限是读(r),如果要写文件,则需要使用写(w)或者追加(a)权限。

w权限,打开一个文件用于写入。如果该文件存在,则覆盖该文件;如果该文件不存在,则创建该文件。

a权限,打开一个文件用于追加。如果该文件存在,在文件末尾追加;如果该文件不存在,则创建该文件。

下面是一个使用w权限打开文件的例子:

例子中使用w权限打开该文件,并写入两行。(如果该文件存在,则内容会被覆盖)

fhand.write() 不会自动添加换行符,所以如果需要换行,需在末尾添加 \n 。

下面我们写一个统计文件中词频的程序。

它会统计文件中各个词的出现的次数,然后由高到低显示出前5个词。

首先我们完成打开和关闭文件的程序内容:

在例子中,由用户输入文件名,并且使用异常捕获以处理文件打开时的错误。

下面对内容进行统计:

这个程序:

如此,我们就在字典中存放了 单词:次数 的键值对。

由于字典不能保存顺序,所以不能对其进行排序。为此,将每个键值对都添加到一个列表中:

在列表 word_list 中,每一项都是一个元组,每个元组第一个值是单词出现的次数,第二个值是单词内容。

对其进行逆向(由大到小)排序:

打印最终结果:

整个程序如下:

下面是程序运行结果的示例:

需要更具体的信息才能回答这个问题。以下是一些可能导致 Python 读取文件错误的情况:

1. 文件路径错误:如果您提供的文件路径不正确,Python 将无法找到文件并读取其内容。请确保文件路径正确,并且文件存在于指定的位置。

2. 文件格式错误:如果您尝试读取的文件格式与您的读取代码不兼容,Python 将无法读取文件。例如,如果您尝试使用文本读取代码读取二进制文件,或者尝试使用 JSON 读取代码读取 XML 文件,Python 将会报错。

3. 文件权限错误:如果您尝试读取未授权的文件,Python 将无法读取其内容并报错。请确保您有足够的权限来读取文件,并且文件未被锁定或占用。

4. 文件过大:如果您尝试读取过大的文件,Python 可能会出现内存不足或读取超时的错误。请确保您的代码能够处理大型文件,并且不会占用过多的内存或 CPU 资源。

5. 文件编码错误:如果您尝试读取的文件使用了错误的编码方式,Python 将无法正确读取文件内容。请确保您使用正确的编码方式来读取文件,并且文件的编码方式与您的代码相匹配。

这些是可能导致 Python 读取文件错误的一些情况。如果您能够提供更具体的错误信息和代码示例,我们可以更准确地诊断问题并提供更好的解决方案。


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存