1.22 python------文件,系统管理,文件遍历

1.文件

1)打开文件的步骤,查看权限,打开模式。

一、打开文件的步骤

打开文件的三个步骤:打开--->操作--->关闭

f = open('/tmp/pass','a')  ##以模式a的方式打开文件,/tmp/pass
f.write('hello')           ##写入hello
f.close()                  ##关闭

二、查看权限

查看文件是否可读,或者可写。返回值为True和False。

print(f.readable())
print(f.writable())

三、打开模式

r:(默认)
    -只能读,不能写
    -读取文件不存在,会报错
    
r+:
    -可读写
    -读取文件不存在,会报错
    
w:
    -write only
    -会清空文件之前的内容
    -文件不存在,不会报错,会创建新的文件并写入

w+:
    -rw
    -会清空文件内容
    -文件不存在,不报错,会创建新的文件
    
a:
    -write only
    -不会清空文件内容
    -文件不存在,不会报错,会创建新的文件并写入

a+:
    -rw
    -文件不存在不报错
    -不会清空文件内容

2)文件的读取操作

--------------------纯文本文件的读取---------------------------

一、文件的指针

如果文件指向指针,读取的时候会从指针的位置开始读取

f = open('/tmp/passwd','rb')    ##rb,以二进制的方式打开,只读。
print(f.read())                 ##实际的效果为一行
print(f.readline())             ##输出一行
print(f.readlines())            ##读取文件内容,返回一个列表,列表的元素分别为文件行的那内容

结果:

从实验结果看出,第一个命令读取完后,剩下的两个命令并没有读出结果,那是因为第一行命令执行完成后,指针指向文件的末尾

b'root:x:0:0:root:/root:/bin/bash\nbin:x:1:1:bin:/bin:/sbin/nologin\ndaemon:x:2:2:daemon:/sbin:/sbin/nologin\nadm:x:3:4:adm:/var/adm:/sbin/nologin\nlp:x:4...........
b''
[]

二、读取当前指针的位置

f = open('/tmp/passwd','rb')
print(f.tell())         ##打印当前光标位置
print(f.read(3))        ##读取三个字符
print(f.tell())         ##打印当前光标位置

结果:

0
b'roo'
3

三、移动指针的方法seek

seek方法,移动指针
    seek第一个参数是偏移量:>0,代表向右移动,<0,代表向左移动
    seek第二个参数是:
        0:移动指针到文件开头
        1:不移动指针
        2:移动指针到末尾

实验:

f = open('/tmp/passwd','rb')
f.seek(-1,2)    ##光标移动到末尾靠左一位
print(f.tell())
f.close()

结果:

2242

四、纯文本文件的读取

f = open('/tmp/passwd','rb')
print(f.read(4))                ##读取前四个字节,类似于head -c 4 /tmp/passwd

结果:

b'root'

练习:读取每一行,去掉空格

f = open('/tmp/passwd','rb')
print([line.strip() for line in f.readlines()])  ##line.strip()会过滤空行

结果:

[b'root:x:0:0:root:/root:/bin/bash', b'bin:x:1:1:bin:/bin:/sbin/nologin',........

f = open('/tmp/passwd','rb')
print(list(map(lambda x:x.strip(),f.readlines())))  ##使用匿名函数,映射函数执行,将执行结果映射到每一个元素。

结果:

[b'root:x:0:0:root:/root:/bin/bash', b'bin:x:1:1:bin:/bin:/sbin/nologin',...........

五、上下文管理器

上下文管理器:打开文件,执行完with语句内容之后,自动关闭文件

#同时打开两个文件对象
with open('/tmp/passwd') as f1,\
    open('/tmp/passwdbackup','w+') as f2:
    #将第一个文件的内容写入到第二个文件中
    f2.write(f1.read())
    #移动指针到文件最开始
    f2.seek(0)
    #读取文件内容
    print(f2.read())

实验结果:

-----------------------非纯文本文件的读取------------------------------


练习1:将一个图片的内容写到另外一个文件

f1 = open('1111.jpg',mode='rb')
content = f1.read()
f1.close()

f2 = open('westos.jpg',mode='wb')
f2.write(content)
f2.close()

实验结果:

练习:创建文件data.txt,文件共100000行,每行存放一个1~100之间的整数,写完后读取文件内容

import random
f=open('data.txt','a+')
for i in range(1000):
    f.write(str(random.randint(1,100))+'\n')
f.seek(0)
print(f.read())
f.close()

结果:

2.操作系统

import os

1).返回操作系统类型

值为:posix,是linux系统,如果是nt,是windows系统
print(os.name)

posix

2).操作系统的详细信息

info = os.uname()
print(info)
print(info.sysname)
print(info.nodename)

posix.uname_result(sysname='Linux', nodename='foundation85.ilt.example.com', release='3.10.0-514.el7.x86_64', version='#1 SMP Wed Oct 19 11:24:13 EDT 2016', machine='x86_64')

Linux
foundation85.ilt.example.com

3).系统环境变量

print(os.environ)

environ({'PATH': '/root/PycharmProjects/shi/venv/bin:/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin:/home/kiosk/.local/bin:/home/kiosk/bin', 'XAUTHORITY': '/root/.xauthOYVtAD', 'IMSETTINGS_MODULE': 'none', 'HISTCONTROL': 'ignoredups', 'XMODIFIERS': '@im=ibus', 'GDMSESSION': 'gnome-classic', 'DBUS_SESSION_BUS_ADDRESS': 'unix:abstract=/tmp/dbus-NgnoJhXrdv,guid=188f11a1a26c40bdb7b892ea5c53ce06', 'PS1': '(venv) ', 'XDG_CURRENT_DESKTOP': 'GNOME-Classic:GNOME', 'MAIL': '/var/spool/mail/kiosk', 'SSH_AGENT_PID': '1645', 'SESSION_MANAGER': 'local/unix:@/tmp/.ICE-unix/1472,unix/unix:/tmp/.ICE-unix/1472', 'USERNAME': 'kiosk', 'LOGNAME': 'kiosk', 'PWD': '/root/PycharmProjects/shi/day7', 'PYCHARM_HOSTED': '1', 'WINDOWID': '37748743', 'PYTHONPATH': '/root/PycharmProjects/shi', 'LESSOPEN': '||/usr/bin/lesspipe.sh %s', 'SHELL': '/bin/bash', 'OLDPWD': '/usr/local/pycharm/bin', 'GNOME_DESKTOP_SESSION_ID': 'this-is-deprecated', 'VIRTUAL_ENV': '/root/PycharmProjects/shi/venv', 'IMSETTINGS_INTEGRATE_DESKTOP': 'yes', 'XDG_SESSION_DESKTOP': 'gnome-classic', 'LS_COLORS': 'rs=0:di=38;5;27:ln=38;5;51:mh=44;38;5;15:pi=40;38;5;11:so=38;5;13:do=38;5;5:bd=48;5;232;38;5;11:cd=48;5;232;38;5;3:or=48;5;232;38;5;9:mi=05;48;5;232;38;5;15:su=48;5;196;38;5;15:sg=48;5;11;38;5;16:ca=48;5;196;38;5;226:tw=48;5;10;38;5;16:ow=48;5;10;38;5;21:st=48;5;21;38;5;15:ex=38;5;34:*.tar=38;5;9:*.tgz=38;5;9:*.arc=38;5;9:*.arj=38;5;9:*.taz=38;5;9:*.lha=38;5;9:*.lz4=38;5;9:*.lzh=38;5;9:*.lzma=38;5;9:*.tlz=38;5;9:*.txz=38;5;9:*.tzo=38;5;9:*.t7z=38;5;9:*.zip=38;5;9:*.z=38;5;9:*.Z=38;5;9:*.dz=38;5;9:*.gz=38;5;9:*.lrz=38;5;9:*.lz=38;5;9:*.lzo=38;5;9:*.xz=38;5;9:*.bz2=38;5;9:*.bz=38;5;9:*.tbz=38;5;9:*.tbz2=38;5;9:*.tz=38;5;9:*.deb=38;5;9:*.rpm=38;5;9:*.jar=38;5;9:*.war=38;5;9:*.ear=38;5;9:*.sar=38;5;9:*.rar=38;5;9:*.alz=38;5;9:*.ace=38;5;9:*.zoo=38;5;9:*.cpio=38;5;9:*.7z=38;5;9:*.rz=38;5;9:*.cab=38;5;9:*.jpg=38;5;13:*.jpeg=38;5;13:*.gif=38;5;13:*.bmp=38;5;13:*.pbm=38;5;13:*.pgm=38;5;13:*.ppm=38;5;13:*.tga=38;5;13:*.xbm=38;5;13:*.xpm=38;5;13:*.tif=38;5;13:*.tiff=38;5;13:*.png=38;5;13:*.svg=38;5;13:*.svgz=38;5;13:*.mng=38;5;13:*.pcx=38;5;13:*.mov=38;5;13:*.mpg=38;5;13:*.mpeg=38;5;13:*.m2v=38;5;13:*.mkv=38;5;13:*.webm=38;5;13:*.ogm=38;5;13:*.mp4=38;5;13:*.m4v=38;5;13:*.mp4v=38;5;13:*.vob=38;5;13:*.qt=38;5;13:*.nuv=38;5;13:*.wmv=38;5;13:*.asf=38;5;13:*.rm=38;5;13:*.rmvb=38;5;13:*.flc=38;5;13:*.avi=38;5;13:*.fli=38;5;13:*.flv=38;5;13:*.gl=38;5;13:*.dl=38;5;13:*.xcf=38;5;13:*.xwd=38;5;13:*.yuv=38;5;13:*.cgm=38;5;13:*.emf=38;5;13:*.axv=38;5;13:*.anx=38;5;13:*.ogv=38;5;13:*.ogx=38;5;13:*.aac=38;5;45:*.au=38;5;45:*.flac=38;5;45:*.mid=38;5;45:*.midi=38;5;45:*.mka=38;5;45:*.mp3=38;5;45:*.mpc=38;5;45:*.ogg=38;5;45:*.ra=38;5;45:*.wav=38;5;45:*.axa=38;5;45:*.oga=38;5;45:*.spx=38;5;45:*.xspf=38;5;45:', 'SHLVL': '4', 'QT_IM_MODULE': 'ibus', 'HISTSIZE': '1000', 'TERM': 'xterm-256color', 'LANG': 'en_US.UTF-8', 'XDG_SESSION_ID': '1', 'DISPLAY': ':0', '_': '/usr/local/pycharm/jre64/bin/java', 'GDM_LANG': 'en_US.UTF-8', 'PYTHONIOENCODING': 'UTF-8', 'DESKTOP_SESSION': 'gnome-classic', 'GPG_AGENT_INFO': '/run/user/1000/keyring/gpg:0:1', 'USER': 'kiosk', 'XDG_MENU_PREFIX': 'gnome-', 'WINDOWPATH': '1', 'VTE_VERSION': '3804', 'XDG_SEAT': 'seat0', 'SSH_AUTH_SOCK': '/run/user/1000/keyring/ssh', 'PYTHONUNBUFFERED': '1', 'HOSTNAME': 'foundation85.ilt.example.com', 'GNOME_SHELL_SESSION_MODE': 'classic', 'XDG_RUNTIME_DIR': '/run/user/1000', 'XDG_VTNR': '1', 'HOME': '/root'})

4).通过key值获取环境变量对应的value值

shell的环境变量env 环境变量
print(os.environ.get('PATH'))

/root/PycharmProjects/shi/venv/bin:/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin:/home/kiosk/.local/bin:/home/kiosk/bin

5).判断是否为绝对路径

print(os.path.isabs('/tmp/hello'))
print(os.path.isabs('hello'))

True
False

6).生成绝对路径

以当前目录为准生成绝对路径
路径拼接
print(os.path.abspath('hello.png'))
print(os.path.join('/home/kiosk','hello.png'))

/root/PycharmProjects/shi/day7/hello.png
/home/kiosk/hello.png

7).获取目录名或文件名

filename = '/home/kiosk/PycharmProjects/westos_python/day08/hello.png'
获取路径中的文件名
print(os.path.basename(filename))
获取路径中的目录名
print(os.path.dirname(filename))

hello.png
/home/kiosk/PycharmProjects/westos_python/day08

8).创建目录/删除目录

os.mkdir('img')
os.makedirs('img/file') #创建递归目录
os.rmdir('img')

9).创建文件/删除文件

os.mknod('westos.txt')
os.remove('westos.txt')

10).文件重命名

os.rename('westos.txt','data.txt')

11).判断文件或者目录是否存在

print(os.path.exists('data.txt'))

True

12).分离后缀名和文件名

print(os.path.splitext('data.txt'))

('data', '.txt')

13).将目录名和文件名分离

print(os.path.split('/tmp/hello/hello.png'))

('/tmp/hello', 'hello.png')

3.遍历目录

1)遍历路径

import os

for root,dir,files in os.walk('/var/www/html'):
    print(root)          ##遍历路径

实验结果:

/var/www/html                    ##根路径
/var/www/html/yumpak    ##根路径下的三个子路径
/var/www/html/rhel7.0
/var/www/html/6.5yumpak

2)遍历目录

import os

for root,dir,files in os.walk('/var/www/html'):
    print(dir)

实验结果:

['yumpak', 'rhel7.0', '6.5yumpak']    ##一共有三个目录,三个目录下面都没有别的目录
[]
[]
[]

3)遍历文件

import os

for root,dir,files in os.walk('/var/www/html'):
    print(files)

实验结果:

['新浪首页.html', 'index.html']  ##根目录下有两个文件
[]                                                ##第一个子目录没有文件
['rhel-server-7.0-x86_64-dvd.iso'] ##第二个子目录有一个文件
[]                                                     ##第三个子目录没有文件

4)输出所有文件的绝对路径

import os
from os.path import join    ##加载拼接库

for root,dir,files in os.walk('/var/www/html'):
    for name in files:
        print(join(root,name))

实验结果:

/var/www/html/新浪首页.html
/var/www/html/index.html
/var/www/html/rhel7.0/rhel-server-7.0-x86_64-dvd.iso

练习1:

# 京东二面笔试题
# 1. 生成一个大文件ips.txt,要求1200行,
     每行随机为172.25.254.0/24段的ip;
# 2. 读取ips.txt文件统计这个文件中ip出现频率排前10的ip;

代码:

import random

def create_ip_file(filename):
    ip = ['172.25.254.' + str(i) for i in range(0,255)]
    with open(filename,'a+') as f:
        for count in range(1200):
            # print(random.sample(ip,1))
            f.write(random.sample(ip,1)[0] + '\n')

create_ip_file('ips.txt')

def sorted_by_ip(filename,count=10):
    ips_dict = dict()
    with open(filename) as f:
        for ip in f:
            if ip in ips_dict:
                ips_dict[ip] += 1
            else:
                ips_dict[ip] = 1
    sorted_ip = sorted(ips_dict.items(),key=lambda x:x[1],reverse=True)[:count]
    return sorted_ip

print(sorted_by_ip('ips.txt'))

实验结果:

[('172.25.254.96\n', 10), ('172.25.254.129\n', 10), ('172.25.254.203\n', 10), ('172.25.254.149\n', 9), ('172.25.254.114\n', 9), ('172.25.254.113\n', 9), ('172.25.254.44\n', 9), ('172.25.254.55\n', 9), ('172.25.254.139\n', 8), ('172.25.254.143\n', 8)]

练习2:

# #   1. 在当前目录新建目录img, 里面包含100个文件, 100个文件名
各不相同(X4G5.png)
# #   2. 将当前img目录所有以.png结尾的后缀名改为.jpg.

代码:

import os
import random
import string

code_str = string.ascii_letters + string.digits


def creatname(len=4):
    return ''.join(random.sample(code_str, len))


os.mkdir('img')
os.chdir('img')
for i in range(100):
    os.mknod(creatname() + '.png')


def modify(dirname, old_suffix, new_suffix):
    if os.path.exists(dirname):
        png_file = filter(lambda filename: filename.endswith(old_suffix), os.listdir(dirname))
        basefiles = [os.path.splitext(filename)[0] for filename in png_file]
        print(basefiles)
        for filename in basefiles:
            oldname = os.path.join(dirname, filename + old_suffix)
            newname = os.path.join(dirname, filename + new_suffix)
            os.rename(oldname, newname)
            print('%s重命名为%s成功' % (oldname, newname))
    else:
        print('%s不存在,不能操作...' % dirname)


modify('img', '.png', '.jpg')

实验结果:

练习3:

生成100个MAC地址并写入文件中,MAC地址前6位(16进制)为01-AF-3B
01-AF-3B
01-AF-3B-xx
01-AF-3B-xx-xx
01-AF-3B-xx-xx-xx

代码:

import random
import string
#随机生成一个mac地址
def create_mac():
    MAC = '01-AF-3B'
    hex_num = string.hexdigits
    for i in range(3):
        n = random.sample(hex_num,2)
        sn = '-' + ''.join(n).upper()
        MAC += sn
    return MAC

# print(create_mac())

#随机生成100个MAC 地址
def main():
    with open('mac.txt','w') as f:
        for i in range(100):
            mac = create_mac()
            print(mac)
            #每生成一个MAC地址,存入文件
            f.write(mac + '\n')

main()

实验结果:

猜你喜欢

转载自blog.csdn.net/qq_41627390/article/details/86691502