1.返回操作系统类型
#值为:posix,表示linux操作系统,如果是nt,是windows操作系统
import os
from os.path import exists,splitext,join
print(os.name)
运行结果为:
posix
2.操作系统的详细信息
info = os.uname()
print(info)
print(info.sysname)
print(info.nodename)
运行结果为:
posix.uname_result(sysname='Linux', nodename='foundation23.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
foundation23.ilt.example.com
3.系统环境变量
print(os.environ)
4.通过key值获取环境变量对应的value值
print(os.environ.get('PATH'))
运行结果为:
/home/kiosk/PycharmProjects/westos/venv/bin:/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin:/home/kiosk/.local/bin:/home/kiosk/bin
1.判断是否为绝对路径
import os
from os.path import exists,splitext,join
print(os.path.isabs('/tmp/westos'))
print(os.path.isabs('/data.txt'))
运行结果为:
True
False
2.生成绝对路径
print(os.path.abspath('hello.png'))
print(os.path.join('/home/kiosk','hello.png'))
print(os.path.join(os.path.abspath('.'),'hello.jpg'))
运行结果为:
/home/kiosk/PycharmProjects/westos/4.5/hello.png
/home/kiosk/hello.png
/home/kiosk/PycharmProjects/westos/4.5/hello.jpg
3.获取目录名或文件名
filename = '/home/kiosk/PycharmProjects/westos/4.5/hello.png'
print(os.path.basename(filename))
print(os.path.dirname(filename))
运行结果为:
hello.png
/home/kiosk/PycharmProjects/westos/4.5
4.创建目录/删除目录
os.mkdir('img')
os.makedirs('img/jpg/png')
os.rmdir('img')
5.创建文件/删除文件
os.mknod('aa.txt')
os.remove('aa.txt')
6.文件重命名
os.rename('data.txt','data1.txt')
7.判断文件或者目录是否存在
print(os.path.exists('imgs'))
print(os.path.exists('data1.txt'))
运行结果为:
False
True
8.分离后缀名和文件名
print(os.path.splitext('hello.png'))
运行结果为:
('hello', '.png')
9.将目录名和文件名分离
print(os.path.split('/tmp/hello/python.jpg'))
运行结果为:
('/tmp/hello', 'python.jpg')
练习一
- 在当前目录新建目录img, 里面包含100个文件, 100个文件名
各不相同(X4G5.png)
def gen_code(len=4):
#随机生成4位验证码
li = random.sample(string.ascii_letters + string.digits,len)
#将列表元素拼接为字符串
return ''.join(li)
def create_files():
#随机生成100个验证码
li = [gen_code() for i in range(100)]
os.mkdir('img')
for name in li:
os.mknod('img/' + name + '.png')
create_files()
- 将当前img目录所有以.png结尾的后缀名改为.jpg.
def modify_suffix(dirname,old_suffix,new_suffix):
:param dirname: 要操作的目录
:param old_suffix: 之前的后缀名
:param new_suffix: 新的后缀名
:return:
"""
if os.path.exists(dirname):
#找出所有以old_suffix结尾的文件名
pngfile = filter(lambda filename:filename.endswith(old_suffix),os.listdir(dirname))
#将文件名和后缀分开
basefiles = [os.path.splitext(filename)[0] for filename in pngfile]
#文件重命名
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_suffix('dir','.jpg','.png')
练习二
京东二面笔试题
- 生成一个大文件ips.txt,要求1200行,
每行随机为172.25.254.0/24段的ip; - 读取ips.txt文件统计这个文件中ip出现频率排前10的ip;
import random
def create_ip_file(filename):
ip =['172.25.254.' + str(i) for i in range(0,255)]
print(random.sample(ip,1))
with open(filename,'a+') as f:
for count in range(1200):
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'))
练习三
生成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 string
import random
print(string.hexdigits)
def creat_mac():
MAC= '01-AF-3B'
# 生成16进制的数
hex_num = string.hexdigits
for i in range(3):
# 从16进制字符串中随机选出两个数字来(返回值是列表)
n = random.sample(hex_num,2)
# 拼接列表中的内容,将小写字母转换成大写
sn ='-' + ''.join(n).upper()
MAC += sn
return MAC
主函数:随机生成100个MAC地址
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()
- 遍历文件
from collections import Iterable
f = open('/tmp/passwd')
print(isinstance(f,Iterable))
for i,item in enumerate(f):
if i == 10:
break
print(i,item)
- 遍历目录
import os
from os.path import join
for root,dir,files in os.walk('/var/log'):
# print(root)
# print(files)
for name in files:
print(join(root,name))