python中文件介绍及相关练习题

文件

  • 打开文件的三个步骤:打开————>操作————>关闭
  • 用/mnt/hui这个文件做实验,给文件777权限便于看到实验效果
    [root@foundation19 mnt]# chmod 777 hui
    [root@foundation19 mnt]# cat hui
    good girl

r(默认):

  • 只能读不能写
  • 读曲文件不存在则,会报错
f = open('/mnt/hui')    ##打开文件,后面不加东西,默认为r
content = f.read()
print(content)        ##打印读出的文件内容
print(f.readable())   ##打印是否可读
print(f.writable())   ##打印是否可写
f.close()      ##打开文件,操作过后一定要记得关闭文件,否则会占用系统资源

结果:
good girl
True
False

r+:

  • 可读写
  • 读取文件不存在,会报错
  • 如果在此模式下写入东西,则会从文件的第一个字母开始替换(默认情况下,从文件指针所指位置开始写入)
f = open('/mnt/hui','r+')
f.write('hui')
print(f.readable())
print(f.writable())
f.close()

结果:
True
True

文件内容会变成:huid girl  (原来是:good girl)

w:

  • 只写
  • 会清空原文件的内容
  • 如果文件不存在,不会报错,会创建新的文件并写入
f = open('/mnt/hui','w')
f.write('hello')
print(f.readable())
print(f.writable())
f.close()

结果:
False    ##不可读
True

此时文件内容为:hello

w+:

  • 可读写
  • 会清空文件内容
  • 文件不存在,不会报错,会创建新文件并写入
f = open('/mnt/hui','w+')
f.write('world')
print(f.readable())
print(f.writable())
f.close()

结果:
True
True

此时文件内容为:world

a:

  • 只写
  • 不覆盖原文件内容
  • 如果文件不存在,不会报错,会创建新的文件并写入
f = open('/mnt/hui','a')
f.write('westos')
print(f.readable())
print(f.writable())
f.close()

结果:
False
True

此时文件内容为:
worldwestos    ##不覆盖原文件内容在后面追加

a+:

  • 可读写
  • 不会清空文件内容,写的内容会在换行追加
  • 文件不存在,不会报错,会创建新的文件并写入
f = open('/mnt/hui','a+')
f.write('hello')
print(f.readable())
print(f.writable())
f.close()

结果:
True
True

此时文件内容为:
worldwestos
hello

文件的读取操作

  • 文件的指针:
f = open('/mnt/hui','r+')
content = f.read()
print(content)
print(f.tell())
f.write('python')
print(f.tell())
print(f.read())
print(f.tell())
f.close()

结果:
hello     ##读取文件内容

6        ##读取完成,指针默认到字符后
12       ##添加'python'后的文件指针+6,变成12
         ##再次读取文件时就为空了,因为:指针所在位置为文件内容的最后
12       ##指针仍为12
  • 区分:
    • .read()
    • .readline()
    • .redalines()
f = open('/mnt/passwd','rb')
print(f.read())f = open('/mnt/passwd','rb')
print(f.read())   ##读取文件内容,在一行输出
f.close()
f = open('/mnt/passwd','rb')
print(f.readline())     ##读取文件内容,输出第一行
f.close()
结果:
b'root:x:0:0:root:/root:/bin/bash\n'
f = open('/mnt/passwd','rb')
print(f.readline()) 
print(f.readline()) ##读取两行内容,则需要写两边readline
f.close()

结果:
b'root:x:0:0:root:/root:/bin/bash\n'
b'bin:x:1:1:bin:/bin:/sbin/nologin\n'

f = open('/mnt/passwd','rb')
print(f.readlines())   ##读取文件内容,返回一个列表,列表的元素分别为文件的每行内容
f.close()
  • 取出文件的前4个字符(类似于head -c 4 /mnt/passwd)
f = open('/mnt/passwd','rb')
print(f.read(4))
f.close()

结果:
b'root'
  • 去掉文件每行的空格(\n也属于空格)
f = open('/mnt/passwd','rb')
print([line.strip()for line in f.readlines()])
f.close()

##也可以用匿名函数写
print(list(map(lambda x:x.strip(),f.readlines())))
  • seek方法,移动指针
    • seek第一个参数是偏移量:>0,代表向右移动;<0,代表向左移动
    • seek第二个参数是:
      0:移动指针到文件开头
      1:不移动指针
      2:移动指针到末尾
      f.seek(0,0) 指针回0
      f.seek(-1,2) 指针指向末尾,再向左移动一个位置
f = open('/mnt/passwd','rb')
print(f.tell())    ##指针一开始在0的位置
print(f.read(3))   ##读取三个字母
print(f.tell())     ##指针变为3
f.seek(0,0)          ##指针回0
print(f.tell())   ##打印指针已经变为0
f.close()

结果:
0
b'roo'
3
0
  • 练习题:
    • 创建文件data.txt,文件共100000行,每行存放一个1~100之间的整数
import random
f = open('date.txt','a+')
for i in range(100000):
    f.write(str(random.randint(1,100)) + '\n')

f.seek(0,0)
print(f.read())
f.close()

文件——with

  • 上下文管理器:打开文件,执行完with语句内容之后,自动关闭文件
    对象
#同时打开两个文件对象
with open('/tmp/passwd') as f1,open('/tmp/passwdbackup','w+') as f2:
    #将第一个文件的内容写入到第二个文件中
    f2.write(f1.read())
    #移动指针到文件最开始
    f2.seek(0)
    #读取文件内容
    print(f2.read())

文件练习题:生成100个MAC地址写入文件

题目要求:

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

# 随机生成一个MAC地址的函数
def creat_mac():
    MAC= '01-AF-3B'
    # 生成16进制的数
    hex_num = string.hexdigits
    # 0123456789abcdefABCDEF
    for i in range(3):
        # 从16进制字符串中随机选出2个数来(返回值为列表)['a', 'd']
        n = random.sample(hex_num,2)
        # 拼接列表中的内容,将小写字母转换为大写-AD
        sn = '-' + ''.join(n).upper()
        MAC += sn
    return MAC

# 主函数,随机生成100MAC地址
def main():
    # 以写的方式打开文件
    with open('mac.txt','w') as f:
        for i in range(100):
            mac= creat_mac()
            print(mac)
            # 每生成一个MAC地址,存入文件(注意换行)
            f.write(mac+'\n')

main()

结果:
01-AF-3B-E5-9B-15
01-AF-3B-C8-39-74
01-AF-3B-CA-86-CA
01-AF-3B-6C-10-C0
01-AF-3B-2D-12-63
01-AF-3B-EA-3E-EF
01-AF-3B-1B-1C-E9
01-AF-3B-FD-CC-DB
01-AF-3B-FE-95-49
01-AF-3B-95-EA-9E
01-AF-3B-DA-75-AD
01-AF-3B-8A-A1-F7
01-AF-3B-BD-75-7D
01-AF-3B-42-B6-B9
01-AF-3B-5D-A2-F6

省略部分结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值