Ruby代码

  1. 1.#读文件
  2. 2.f = File.open("myfile.txt", "r")
  3. 3.f.each_line do|line|
  4. 4.puts "I read this line: #{line}"
  5. 5.end
  6. #读文件
  7. f = File.open("myfile.txt", "r")
  8. f.each_line do|line|
  9. puts "I read this line: #{line}"
  10. end

Ruby代码

  1. 1.File.foreach("myfile.txt") do|line|
  2. 2.puts "I read this line: #{line}"
  3. 3.end
  4. File.foreach("myfile.txt") do|line|
  5. puts "I read this line: #{line}"
  6. end

Ruby代码

  1. 1.f = File.open("myfile.txt", "r")
  2. 2.line = f.gets
  3. 3.puts "The line I read is: #{line}"
  4. f = File.open("myfile.txt", "r")
  5. line = f.gets
  6. puts "The line I read is: #{line}"

Ruby代码

  1. 1.#写操作
  2. 2.File.open('filename','w') do |f|
  3. 3.  f.puts lines
  4. 4.end
  5. #写操作
  6. File.open('filename','w') do |f|
  7. f.puts lines
  8. end

Ruby代码

  1. 1.#得到当前目录所有文件名
  2. 2.    files = Dir.glob('*.rd')
  3. #得到当前目录所有文件名
  4. files = Dir.glob('*.rd')

Ruby代码

  1. 1.#删除特定目录所有文件名
  2. 2.Dir.glob('*.rd').each{|f| File.delete f}
  3. #删除特定目录所有文件名
  4. Dir.glob('*.rd').each{|f| File.delete f}

本文摘自互联网.原文作者不详.

1.创建文件夹 
Dir.new %%1 
Dir::mkdir #不指定目录全名称时,缺省为工作目录 
Dir::chdir() 改变当前脚本工作目录 
FileUtils.mkdir 'test' 
file = File.new("cmd.txt") 
file.each do |line| 
puts line if line =~ /target/ 
end

2.创建文件 
改变当前根目录

Dir.chdir("/home/guy/sandbox/tmp")  
  
Dir.chroot("/home/guy/sandbox") 
Dir.new %%1 
#Dir::rmdir #不指定目录全名称时,缺省为工作目录

3.删除文件 
改变当前根目录 
Dir.chdir("/home/guy/sandbox/tmp")  
Dir.chroot("/home/guy/sandbox") 
Dir.new %%1 
#Dir::rmdir #不指定目录全名称时,缺省为工作目录

4.删除文件夹 
#require 'fileutils'  
FileUtils.rm_r(%%1)

5.删除一个文件下夹所有的文件夹 
Dir::chdir 
Dir::pwd属性或者Dir.getwd() 
#改变当前脚本工作目录

6.清空文件夹 
Dir::chdir %%1 改变当前脚本工作目录 
Dir::rmdir #不指定目录全名称时,缺省为工作目录 
Dir.new %%1

#require 'ftools' 
FileUtils.mkdir 'test' 
file = File.new(%%1)  #"cmd.txt" 
file.each do |line| 
puts line if line =~ /target/ 
end

7.读取文件 
#require 'ftools' 
File.open(%%1).readlines #'文件名'

#require 'ftools' 
arr = IO.readlines(%%1)  #"myfile" 
lines = arr.size 
#puts "myfile has #{lines} lines in it." 
#longest = arr.collect {|x| x.length}.max 
#puts "The longest line in it has #{longest} characters."

8.写入文件 
f=open(%%1,"w") 
f.puts(%%2)

9.写入随机文件 
#require 'ftools' 
file = File.open(%%1,"w")  
file.seek(5)  
str = file.gets # "fghi"

#require 'ftools' 
File.open('文件名') 
File.open("cmd.txt","r") do |file| 
while line=file.gets 
puts line 
end 
end 
puts 
file=File.new("cmd.txt","r") 
file.each_line do |line| 
puts line 
end 
IO.foreach("cmd.txt") do |line| 
puts line if line =~ /target/ 
puts line if line !~ /target/ 
end 
### 
Dir#pos 
返回当前子文件指针

Dir#pos= 
设置子文件指针

Dir#rewind 
设置子文件指针到起始位置

Dir#seek 
设置子文件指针

Dir#tell 
获取当前指针

10.读取文件属性 
#文件中是否有内容,(返回false为有内容,返回true为空) 
File.new('文件名').stat.zero? 
#文件大小 
File.size?('文件名') 
flag1 = FileTest::zero?("file1") 
flag2 = FileTest::size?("file2") 
size1 = File.size("file1") 
size2 = File.stat("file2").size 
### 
File::atime(filename) 
返回指定文件的最后访问时间

11.写入属性

12.枚举一个文件夹中的所有文件夹 
#require 'ftools' 
puts Dir.glob('**/*').each { | file | file.downcase }

#要区分目录和普通文件我们这样使用 
file1 = File.new("/tmp") 
file2 = File.new("/tmp/myfile") 
test1 = file1.directory? # true 
test2 = file1.file? # false 
test3 = file2.directory? # false 
test4 = file2.file? # true 
### 
遍历目录 
Dir.foreach(%%1) { |entry| puts entry}

13.复制文件夹 
require "fileutils" 
FileUtils.cp %%1,%%2

14.复制一个目录下所有的文件夹到另一个文件夹下 
#require 'FileUtils' 
list=Dir.entries(%%1) 
list.each_index do |x| 
FileUtils.cp "#{list[x]}",%%2 if !File.directory?(list[x]) 
end

15.移动文件夹 
#require 'FileUtils' 
FileUtils.mv %%1,%%2

16.移动一个目录下所有的文件夹到另一个目录下 
#require 'FileUtils' 
list=Dir.entries(%%1) 
list.each_index do |x| 
FileUtils.mv "#{list[x]}",%%2 if !File.directory?(list[x]) 
end

17.以一个文件夹的框架在另一个目录创建文件夹和空文件 
######################### 
//文件是否存在 
File.exist?('文件名') 
flag = FileTest::exist?("LochNessMonster") 
flag = FileTest::exists?("UFO") 
######################### 
require 'rubygems' 
require 'ruby-debug' 
require "find"

module Cz_dirtools

def mkdirs_to(tar,src=Dir.getwd) 
#debugger 
if tar.class==NilClass then 
puts "PLZ input target directory name..." 
return 
elsif !FileTest.directory?(tar)#如果tar不是一个目录 
puts ("Creating #{File.expand_path(tar)}") 
Dir.mkdir("#{File.expand_path(tar)}")#创建tar目录 
end

src=if FileTest.directory?(src) then 
src#如果src是一个目录名,则返回自身 
else 
File.dirname(src)#如果src为一个文件名,则返回该文件所在目录 
end 
#Dir.foreach可以复制目标路径第一层目录结构而不复制子目录 
#~ Dir.foreach(src) do |dir| 
#~ if FileTest.directory?(dir) && dir!=tar && dir!='..' &&dir!='.' then #忽略自身,忽略上级目录"..",忽略本级目录"." 
#~ #puts dir 
#~ begin 
#~ Dir.mkdir("#{File.expand_path(tar)}/#{dir}") 
#~ rescue#如果该目录已存在则直接跳过否则创建该目录 
#~ end 
#~ end 
#~ end 
#Find.find可以复制目标路径的完整目录结构,包括子目录 
dirs=Array.new 
Find.find(src) do |dir| 
unless
!FileTest.directory?(dir) || File.basename(dir)==tar ||
File.basename(dir)=='..' || File.basename(dir)=='.' ||
File.basename(dir)==File.basename(src)#忽略自身,忽略上级目录"..",忽略本级目录"." 
dirs<<dir 
end 
end 
#puts dirs 
dirs.each do |dir| 
begin 
Dir.mkdir("#{File.expand_path(tar)}/#{dir.gsub(src,'')}") 
rescue#如果该目录已存在则直接跳过否则创建该目录 
end 
end 
end

end

require 'rubygems' 
require 'ruby-debug' 
require "find"

module Cz_dirtools

def mkdirs_to(tar,src=Dir.getwd) 
#debugger 
if tar.class==NilClass then 
puts "PLZ input target directory name..." 
return 
elsif !FileTest.directory?(tar)#如果tar不是一个目录 
puts ("Creating #{File.expand_path(tar)}") 
Dir.mkdir("#{File.expand_path(tar)}")#创建tar目录 
end

src=if FileTest.directory?(src) then 
src#如果src是一个目录名,则返回自身 
else 
File.dirname(src)#如果src为一个文件名,则返回该文件所在目录 
end 
#Dir.foreach可以复制目标路径第一层目录结构而不复制子目录 
#~ Dir.foreach(src) do |dir| 
#~ if FileTest.directory?(dir) && dir!=tar && dir!='..' &&dir!='.' then #忽略自身,忽略上级目录"..",忽略本级目录"." 
#~ #puts dir 
#~ begin 
#~ Dir.mkdir("#{File.expand_path(tar)}/#{dir}") 
#~ rescue#如果该目录已存在则直接跳过否则创建该目录 
#~ end 
#~ end 
#~ end 
#Find.find可以复制目标路径的完整目录结构,包括子目录 
dirs=Array.new 
Find.find(src) do |dir| 
unless
!FileTest.directory?(dir) || File.basename(dir)==tar ||
File.basename(dir)=='..' || File.basename(dir)=='.' ||
File.basename(dir)==File.basename(src)#忽略自身,忽略上级目录"..",忽略本级目录"." 
dirs<<dir 
end 
end 
#puts dirs 
dirs.each do |dir| 
begin 
Dir.mkdir("#{File.expand_path(tar)}/#{dir.gsub(src,'')}") 
rescue#如果该目录已存在则直接跳过否则创建该目录 
end 
end 
end

end

18.复制文件 
#require 'FileUtils' 
FileUtils.cp %%1, %%2

19.复制一个目录下所有的文件到另一个目录 
#require 'FileUtils' 
list=Dir.entries(%%1) 
list.each_index do |x| 
FileUtils.cp "#{list[x]}",%%2 if !File.directory?(list[x]) 
end

20.提取扩展名

21.提取文件名 
%%2 = File.basename(%%1)

22.提取文件路径 
%%2 = File.dirname(%%1)

23.替换扩展名

24.追加路径

25.移动文件

26.移动一个文件夹下所有文件到另一个目录 
#require 'FileUtils' 
list=Dir.entries(%%1) 
list.each_index do |x| 
FileUtils.mv "#{list[x]}",%%2 if !File.directory?(list[x]) 
end

27.指定目录下搜索文件 
#require "find"  
  
def findfiles(dir, name)  
 list = []  
 Find.find(dir) do |path|  
  Find.prune if [".",".."].include? path  
  case name  
   when String  
    list << path if File.basename(path) == name  
   when Regexp  
    list << path if File.basename(path) =~ name  
  else  
   raise ArgumentError  
  end  
 end  
 list  
end  
  
findfiles %%1,%%2 #"/home/hal", "toc.txt"

28.打开对话框

29.文件分割 
逐字节对文件进行遍历

  可以使用each_byte方法,如果你想要转换byte到字符的话使用chr方法:

file = File.new("myfile")  
e_count = 0  
file.each_byte do |byte|  
 e_count += 1 if byte == ?e  
end

30.文件合并 
逐字节对文件进行遍历

  可以使用each_byte方法,如果你想要转换byte到字符的话使用chr方法:

file = File.new("myfile")  
e_count = 0  
file.each_byte do |byte|  
 e_count += 1 if byte == ?e  
end

31.文件简单加密

32.文件简单解密

33.读取ini文件属性

34.合并一个文件下所有的文件

35.写入ini文件属性

36.获得当前路径 
File.dirname($0)

37.读取XML数据库

38.写入XML数据库

39.ZIP压缩文件 
#require 'rubygems'  
#require 'zip/zipfilesystem' 
Zip::ZipFile.open(%%1, Zip::ZipFile::CREATE) do |zip|   #'zipfile.zip' 
zip.file.open('file1', 'w') { |f| f << 'This is file 1.' }   
zip.dir.mkdir('sub_dir')   
zip.file.open('sub_dir/file2', 'w') { |f| f << 'This is file 2.' }   
end

40.ZIP解压缩

41.获得应用程序完整路径

42.ZIP压缩文件夹 
#require 'rubygems'  
#require 'zip/zipfilesystem' 
def compress   
  Zip::ZipFile.open 'zipfile.zip', Zip::ZipFile::CREATE do |zip|   
    add_file_to_zip('dir', zip)   
  end  
end  
  
def add_file_to_zip(file_path, zip)   
  if File.directory?(file_path)   
    Dir.foreach(file_path) do |sub_file_name|   
      add_file_to_zip("#{file_path}/#{sub_file_name}", zip) unless sub_file_name == '.' or sub_file_name == '..'  
    end  
  else  
    zip.add(file_path, file_path)   
  end  
end  
add_file_to_zip %%1,%%2

43.递归删除目录下的文件 
#require 'ftools' 
file_path = String.new 
file_path="D:" 
    if File.directory? file_path 
      Dir.foreach(file_path) do |file| 
        if file!="." and file!=".." 
puts "File:"+file 
        end 
      end 
    end

44.验证DTD

45.Schema 验证

46.Grep 
#!/usr/bin/env ruby 
# Grep with full regexp-functionality via ruby

if ARGV.shift == "-p" 
  pattern = Regexp.new(ARGV.shift) 
else 
  puts "Please give me a pattern with the '-p' option" 
  exit 
end 
ARGV.each do |filename| 
  File.open(filename) do |file| 
    file.each do |line| 
      puts "#{filename} #{file.lineno.to_s}: #{line}" if 
pattern.match(line) 
    end 
  end 
end

Using it via: rgrep -p '/delete /i' *.php does not match anything, but 
this 
#!/usr/bin/env ruby 
# Grep with full regexp-functionality via ruby

if ARGV.shift == "-p" 
  pattern = Regexp.new(ARGV.shift) 
else 
  puts "Please give me a pattern with the '-p' option" 
  exit 
end 
ARGV.each do |filename| 
  File.open(filename) do |file| 
    file.each do |line| 
      puts "#{filename} #{file.lineno.to_s}: #{line}" if /delete 
/i.match(line) 
    end 
  end 
end

47.直接创建多级目录 
#require "fileutils" 
FileUtils.makedirs(%%1)

48.批量重命名

49.文本查找替换 ReplaceText

50.文件关联

51.操作Excel文件

52.设置JDK环境变量

53.选择文件夹对话框

54.删除空文件夹

55.发送数据到剪贴板

56.从剪贴板中取数据

57.获取文件路径的父路径

58.创建快捷方式 CreateShortCut

59.弹出快捷菜单

60.文件夹复制到整合操作

61.文件夹移动到整合操作

62.目录下所有文件夹复制到整合操作

63.目录下所有文件夹移动到整合操作

64.目录下所有文件复制到整合操作

65.目录下所有文件移动到整合操作

66.对目标压缩文件解压缩到指定文件夹

67.创建目录副本整合操作

68.打开网页

69.删除空文件夹整合操作

70.获取磁盘所有分区后再把光驱盘符去除(用"\0"代替),把结果放在数组allfenqu[] 中,数组中每个元素代表一个分区盘符,不包括 :\\ 这样的路径,allfenqu[]数组开始时存放的是所有盘符。 
当我用这样的代码测试结果是正确的,光驱盘符会被去掉: 
CString root; //root代表盘符路径 
for(i=0;i<20;i++) //0-20代表最大的盘符数 

root.Format("%c:\\",allfenqu[i]); 
if(GetDriveType(root)==5) 
allfenqu[i]='\0'; 
}

但我用这样的代码时结果却无法去掉光驱盘符,allfenqu[]中还是会包含光驱盘符: 
CString root; 
for(i=0;i<20;i++) 

root=allfenqu[i]+":\\"; 
if(GetDriveType(root)==5) 
allfenqu[i]='\0'; 
}

ruby文件操作的更多相关文章

  1. 雷林鹏分享:Ruby 文件的输入与输出

    Ruby 文件的输入与输出 Ruby 提供了一整套 I/O 相关的方法,在内核(Kernel)模块中实现.所有的 I/O 方法派生自 IO 类. 类 IO 提供了所有基础的方法,比如 read. wr ...

  2. 第十二章 Python文件操作【转】

    12.1 open() open()函数作用是打开文件,返回一个文件对象. 用法格式:open(name[, mode[, buffering[,encoding]]]) -> file obj ...

  3. 【.NET深呼吸】Zip文件操作(1):创建和读取zip文档

    .net的IO操作支持对zip文件的创建.读写和更新.使用起来也比较简单,.net的一向作风,东西都准备好了,至于如何使用,请看着办. 要对zip文件进行操作,主要用到以下三个类: 1.ZipFile ...

  4. 野路子出身PowerShell 文件操作实用功能

    本文出处:http://www.cnblogs.com/wy123/p/6129498.html 因工作需要,处理一批文件,本想写C#来处理的,后来想想这个是PowerShell的天职,索性就网上各种 ...

  5. Node基础篇(文件操作)

    文件操作 相关模块 Node内核提供了很多与文件操作相关的模块,每个模块都提供了一些最基本的操作API,在NPM中也有社区提供的功能包 fs: 基础的文件操作 API path: 提供和路径相关的操作 ...

  6. 归档NSKeyedArchiver解归档NSKeyedUnarchiver与文件管理类NSFileManager (文件操作)

    ========================== 文件操作 ========================== 一.归档NSKeyedArchiver 1.第一种方式:存储一种数据. // 归档 ...

  7. SQL Server附加数据库报错:无法打开物理文件,操作系统错误5

    问题描述:      附加数据时,提示无法打开物理文件,操作系统错误5.如下图: 问题原因:可能是文件访问权限方面的问题. 解决方案:找到数据库的mdf和ldf文件,赋予权限即可.如下图: 找到mdf ...

  8. 通过cmd完成FTP上传文件操作

    一直使用 FileZilla 这个工具进行相关的 FTP 操作,而在某一次版本升级之后,发现不太好用了,连接老是掉,再后来完全连接不上去. 改用了一段时间的 Web 版的 FTP 工具,后来那个页面也 ...

  9. Linux文件操作的主要接口API及相关细节

    操作系统API: 1.API是一些函数,这些函数是由linux系统提供支持的,由应用层程序来使用,应用层程序通过调用API来调用操作系统中的各种功能,来干活 文件操作的一般步骤: 1.在linux系统 ...

随机推荐

  1. L-BFGS

    L-BFGS算法比较适合在大规模的数值计算中,具备牛顿法收敛速度快的特点,但不需要牛顿法那样存储Hesse矩阵,因此节省了大量的空间以及计算资源.本文主要通过对于无约束最优化问题的一些常用算法总结,一 ...

  2. 【转】Swig使用指南

    如何使用 API swig.init({ allowErrors: false, autoescape: true, cache: true, encoding: 'utf8', filters: { ...

  3. ASP.NET Core 2 学习笔记(八)URL重写

    路由跟URL 重写的功能性略有不同.路由是将Request 找到对应的服务,而URL 重写是为了推卸责任转送Request.本篇将简单介绍下ASP.NET Core的URL重写(URL Rewrite ...

  4. RabbitMQ广播模式

    广播模式:1对多,produce发送一则消息多个consumer同时收到.注意:广播是实时的,produce只负责发出去,不会管对端是否收到,若发送的时刻没有对端接收,那消息就没了,因此在广播模式下设 ...

  5. 在linux下搭建python+django环境

    下载python3,进行编译安装,运行django程序 在 /opt目录中安装 cd /opt 1.解决python编译安装所需的软件依赖 yum install gcc patch libffi-d ...

  6. Text and Binary modes

    http://perlmaven.com/what-is-a-text-file https://cygwin.com/cygwin-ug-net/using-textbinary.html Text ...

  7. 牛客多校第四场 J.Hash Function(线段树优化建图+拓扑排序)

    题目传送门:https://www.nowcoder.com/acm/contest/142/J 题意:给一个hash table,求出字典序最小的插入序列,或者判断不合法. 分析: eg.对于序列{ ...

  8. dos新建文件夹 新建文件

    https://jingyan.baidu.com/article/49ad8bceb0237f5834d8fa19.html 新建文件夹: mkdir kkk 新建kkk文件夹 新建文件: type ...

  9. PHP之旅4 php 超全局变量

    预定义数组: 自动全局变量---超全局数组 1.包含了来自web服务器,客户端,运行环境和用户输入的数据 2.这些数组比较特别 3.全局范围内自动生效,都可以直接使用这些数组 4.用户不能自定义这些数 ...

  10. 经典MVC框架技术-struts2基础知识

    Struts2框架简介 struts2框架是在struts1和webwork技术的基础上,进行合并的全新框架,struts2以Webwork为核心,采用拦截器来处理用户的请求,这样的设计使得业务逻辑控 ...