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. spring mvc配置ObjectMapper忽略无法识别的字段,以及一些博客推荐

    通过Spring的MethodInvokingFactoryBean类实现的调用configure方法,此方法返回调用该方法的本身实例. 配置完毕后,可以在spring mvc的消息处理器中使用,为了 ...

  2. LeetCode134:Gas Station

    题目: There are N gas stations along a circular route, where the amount of gas at station i is gas[i]. ...

  3. 如何使用T-SQL备份还原数据库及c#如何调用执行?

    准备材料:Microsoft SQL Server一部.需要还原的bak文件一只 一.备份 数据库备份语句:user master backup database 数据库名 to disk='保存路径 ...

  4. web窗体ListView配置分页

    一.配置objectDataSource 1.选择业务逻辑层的类,再选择对应的分页方法 2.配置Select对应的方法,必须是一个带两个整型参数的方法,第一个参数表示要查看的第一条记录的前一条,第二个 ...

  5. 第五章 企业项目开发--mybatis注解与xml并用

    本章的代码建立在第四章<Java框架整合--切分配置文件>的项目代码之上,链接如下: http://www.cnblogs.com/java-zhao/p/5118184.html 在实际 ...

  6. Unix下cp、tar、sudo命令的使用

    环境 Ubuntu14.04 (这里用这样一个类Unix系统来代替Unix,sudo命令也是linux下的一个命令) 实例 : Ubuntu firefox flash插件的安装 到Adobe下载ta ...

  7. JQuery Mobile - 需要注意问题!

    一,JQuery Mobile 和 JQuery 版本对接,一定要选用和当前JQuery Mobile 对应版本的JQuery . 二,在台式机的模拟器和真机中的显示结果可能不一样.我在台式机中使用的 ...

  8. 769. Max Chunks To Make Sorted

    Given an array arr that is a permutation of [0, 1, ..., arr.length - 1], we split the array into som ...

  9. Qt使用gtest进行C++单元测试-01

    环境: win7/win10+qt5.8.0(MinGW), 1.gtest获取: 从:https://www.bogotobogo.com/cplusplus/google_unit_test_gt ...

  10. Elasticsearch java API (23)查询 DSL Geo查询

    地理查询编辑 Elasticsearch支持两种类型的地理数据: geo_point纬度/经度对字段的支持,和 geo_shape领域,支持点.线.圆.多边形.多等. 这组查询: geo_shape  ...