文件系统00

00
编写一个程序,统计当前目录下每个文件类型的文件数
import os

all_files = os.listdir(os.curdir)
type_dict =dict()

for each_file in all_files:
  if os.path.isdir(each_file):
    type_dict.setdefault(‘文件夹‘, 0)
    type_dict[‘文件夹‘] += 1

  else:
    ext = os.path.splitext(each_file)[1]
    type_dict.setdefault(ext, 0)
    type_dict[ext] += 1

  for each_type in type_dict.keys():
    print(‘该文件夹下共有类型为【%s】的文件 %d 个‘ % (each_type,
    type_dict[each_type]))

01
编写一个程序,计算当前文件夹下所有文件的大小。
import os

all_files = os.listdir(os.curdir)
file_dict = dict()

for each_file in all_files:
  if os.path.isfile(each_file):
    file_size = os.path.getsize(each_file)
    file_dict[each_file] = file_size

  for each in file_dict.items():
    print(‘%s【%dBytes】‘ % (each[0], each[1]))

02
编写一个程序,用户输入文件名以及开始搜索的路径,搜索该文件是否存在。如遇到文件夹,则进入文件夹继续搜索
import os

def search_file(file_path,file_name):
os.chdir(file_path)

all_files = os.listdir(os.curdir)
for each_file in all_files:
  if each_file == file_name:
    print(os.getcwd() + os.sep + each_file)
    if os.path.isdir(each_file):
      search_file(each_file, file_name)
      os.chdir(os.pardir)

file_path = input(‘请输入需要查找的路径:‘)
file_name = input(‘请输入需要查找的文件:‘)
search_file(file_path,file_name)

03
编写一个程序,用户输入开始搜索的路径,查找该路径下(包含子文件夹内)所有的视频格式文件(要求查找mp4 rmvb, avi的格式即可),并把创建一个文件(vedioList.txt)存放所有找到的文件的路径
import os

def search_file(file_path,file_name):
os.chdir(file_path)

all_files = os.listdir(os.curdir)
for each_file in all_files:
  ext = os.path.splitext(each_file)[1]
  if ext in file_name:
    video_list.append(os.getcwd() + os.sep + each_file + os.linesep)
  if os.path.isdir(each_file):
    search_file(each_file, file_name)
    os.chdir(os.pardir)

file_path = input(‘请输入需要查找的路径:‘)
program_dir = os.getcwd()

file_name = [‘.mp4‘, ‘.avi‘, ‘.rmvb‘]
video_list = []

search_file(file_path, file_name)
f = open(program_dir + os.sep + ‘videolist.txt‘, ‘w‘)
f.writelines(video_list)
f.close()

04
编写一个程序,用户输入关键字,查找当前文件夹内(如果当前文件夹内包含文件夹,则进入文件夹继续搜索)所有含有该关键字的文本文件(.txt后缀),要求显示该文件所在的位置以及关键字在文件中的具体位置(第几行第几个字符)
import os

def print_pos(key_dict):
keys = key_dict.keys()
keys = sorted(keys)
for each_key in keys:
  print(‘关键字出现在第 %s 行,第 %s 个位置。‘ %
    (each_key, str(key_dict[each_key])))

def pos_in_line(line, key):
  pos = []
  begin = line.find(key)
  while begin != -1:
    pos.append(begin + 1)
    begin = line.find(key, begin + 1)

  return pos

def search_in_file(file_name, key):
  f = open(file_name)
  count = 0
  key_dict = dict()

  for each_line in f:
    count += 1
    if key in each_line:
      pos = pos_in_line(each_line, key)
      key_dict[count] = pos

  f.close()
  return key_dict

def search_files(key, detail):
  all_files = os.walk(os.getcwd())
  txt_files = []

  for i in all_files:
    for each_file in i[2]:
      if os.path.splitext(each_file)[1] == ‘.txt‘:
        each_file = os.path.join(i[0], each_file)
        txt_files.append(each_file)

  for each_txt_file in txt_files:
    key_dict = search_in_file(each_txt_file, key)
    if key_dict:
      print(‘================================================================‘)
      print(‘在文件【%s】中找到关键字【%s】‘ % (each_txt_file, key))
    if detail in [‘YES‘, ‘Yes‘, ‘yes‘]:
      print_pos(key_dict)

key = input(‘请将该脚本放于待查找的文件夹内,请输入关键字:‘)
detail = input(‘请问是否需要打印关键字【%s】在文件中的具体位置(YES/NO):‘ % key)
search_files(key, detail)

文件系统00

时间: 2024-07-30 00:43:32

文件系统00的相关文章

Web for pentester_writeup之File Upload篇

Web for pentester_writeup之File Upload篇 File Upload(文件上传) Example 1 直接上传一句话木马,使用蚁剑连接 成功连接,获取网站根目录 Example 2 可以看到上传文件做了相关限制,不允许上传PHP文件, 修改后缀名为linux不识别的xxx,上传 同样成功连接,我们还可以修改后缀名为.php3,有些系统.php4,.php5也能成功执行 文件上传绕过方式有很多,包含 前台脚本检测扩展名绕过 Content-Type检测文件类型绕过

资金计划报表sql 希望大家给点意见,指出我的存储过程里面的错误的地方

IF EXISTS (SELECT * FROM sys.procedures WHERE object_id = OBJECT_ID(N'[dbo].[Proc_FM_RollingBudgetRollingCapitalplan]'))DROP proc [dbo].[Proc_FM_RollingBudgetRollingCapitalplan]GO --exec [Proc_FM_RollingBudgetRollingCapitalplan] 6342,2015,5 --exec [P

Linux基础之文件系统简介及其系统管理工具

常见的文件系统 Linux文件系统: ext2, ext3, ext4, xfs, btrfs, reiserfs, jfs, swap swap: 交换分区 光盘:iso9660 Windows:fat32, ntfs Unix: FFS, UFS, JFS2 网络文件系统:NFS, CIFS 集群文件系统:GFS2, OCFS2 分布式文件系统:ceph, moosefs, mogilefs, GlusterFS, Lustre 实验环境CentOS7.2 Linux根据其是否支持"jour

NFS网络文件系统的应用

    NFS是linux中非常常见的一种网络文件系统,其的搭建配置也非常简单,在一般的企业应用中较为广泛.下面就介绍一下NFS在企业环境中的基本应用,在应用中我们也可以更好的理解NFS网络文件系统的工作原理. 1)企业中一般应用场景 如上图一般我们要在中心服务器上设置好共享目录,由其他客户端挂在相应的共享目录,这样客户端服务器就可以想在本地一样往中心服务器上读写数据了.由上图也可以看出NFS服务一般由服务端和客户端组成. 2)rpc服务 既然想使用NFS服务就必须了解RPC服务的相关内容,因为

Node.js v0.12.0API手册--文件系统

File System Stability: 3 - Stable 文件系统模块是一个简单包装的标准 POSIX 文件 I/O 操作方法集.您可以通过调用require('fs')来获取该模块.文件系统模块中的所有方法均有异步和同步版本. 文件系统模块中的异步方法需要一个完成时的回调函数作为最后一个传入形参. 回调函数的构成由您调用的异步方法所决定,通常情况下回调函数的第一个形参为返回的错误信息. 如果异步操作执行正确并返回,该错误形参则为 null或者undefined. 如果您使用的是同步版

【转】LINUX文件系统剖析

引自:http://www.ibm.com/developerworks/cn/linux/l-linux-filesystem/   在文件系统方面,Linux? 可以算得上操作系统中的 "瑞士军刀".Linux 支持许多种文件系统,从日志型文件系统到集群文件系统和加密文件系统.对于使用标准的和比较奇特的文件系统以及开发文件系统来说,Linux 是极好的平台.本文讨论 Linux 内核中的虚拟文件系统(VFS,有时候称为虚拟文件系统交换器),然后介绍将文件系统连接在一起的主要结构.

路由器文件系统与提取

1.路由器文件系统 我们通常所说的更新路由器是指更新路由器的固件,不同的路由器使用了不同呃硬件平台.操作系统及固件.通常情况下,路由器的固件中包含操作系统的内核及文件系统. 1.1.路由器固件 路由器固件不是硬件,而是软件,在路由器中,它通常是被固化在只读存储器中的,所以称为固件. 在进行漏洞分析时获取路由器固件的通常有两种方式: 一.从路由器厂商提供的更新网站下载: 二.通过硬件接入,从路由器的Flash中提取固件. 路由器固件中包含了该路由器中所有的可执行程序及配置文件信息,这些信息对于我们

使用NFS启动Tiny4412开发板根文件系统

  1.Ubuntu14.04上搭建NFS服务 1.1.安装NFS服务 $ sudo apt-get install nfs-kernel-server    //安装NFS服务 1.2 创建Tiny4412开发板根文件系统 这部分内容参考<Busybox构建根文件系统和制作Ramdisk>部分. 假设Tiny4412开发板根文件系统路径为/home/felix/nfs 1.3. 配置NFS服务器 配置NFS主要涉及配置文件/etc/exports,它用于NFS服务器端,其中列出了NFS服务器

RHCS之用css_tool命令创建HA集群及创建gfs2集群文件系统

准备环境 node1:192.168.139.2 node2:192.168.139.4 node4:192.168.139.8 node5:192.168.139.9 node1 作为target端 node2 node4 node5 作为initiator端 并且将node2 node4 node5安装cman+rgmanager后配置成一个三节点的RHCS高可用集群,因为gfs2为一个集群文件系统,必须借助HA高可用集群将故障节点Fence掉,及借助Message Layer进行节点信息传