RUBY语言怎么判断指定目录是否存在

Python026

RUBY语言怎么判断指定目录是否存在,第1张

ruby中判断目录是否存在:

File.directory?(argu)

ruby文件操作:使用File类的静态方法,或者File类的实例对象

File类的静态方法

File::atime(filename)

返回指定文件的最后访问时间

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=0i<20i++) //0-20代表最大的盘符数

{

root.Format("%c:\\",allfenqu[i])

if(GetDriveType(root)==5)

allfenqu[i]='\0'

}

但我用这样的代码时结果却无法去掉光驱盘符,allfenqu[]中还是会包含光驱盘符:

CString root

for(i=0i<20i++)

{

root=allfenqu[i]+":\\"

if(GetDriveType(root)==5)

allfenqu[i]='\0'

}

Category/Util

sstoolkit    一套Category类型的库,附带很多自定义控件 功能不错~

BlocksKit    将Block风格带入UIKit和Founcation

cocoa-helpers    一些Cocoa的扩展 2年前的工程

CoconutKit    一系列扩展和一些自定组件

STUtils    一系列扩展包

PSFoundation    一系列扩展 和功能增强

ConciseKit    一系列宏定义 挺有意思

DTFoundation    又一系列扩展。。。

BBBootstrap    一些常见功能的扩展库

cooliris-toolkit    cooliris出品的基础工具库,从GoogleCode clone过来

BaseKit    一套基础工具库

NSObject-Utility-Categories    如题

NSArray-Utilities    如题

aqtoolkit    一些常用的东西

DLIntrospection    一些NSObject的扩展

NSDate-Extensions    如题日期

ALActionBlocks    在UIControl上添加的Block事件

jrswizzle    主要是swizzling

moriarty    一些还算有用的功能

QSUtilities    一些基础库 (Instagram有用到)

libextobjc    一堆oc的扩展

PrettyTimestamp    友好时间的扩展

ios-jail-break-detector    检测是否越狱 有上线

crackify    检测App是否被破解

NSBundle-OBCodeSigningInfo    检查当前签名、Sandbox状态 MacOSX

UIView-AnimatedProperty    为UIView添加动画效果的property,有用到swizzle

Block-KVO    Block风格的KVO~

MTDates    一些Data的category

CocoaSecurity    常见的哈希、加密解密算法

sskeychain    访问keychain 支持iOS Mac

ABContactHelper    访问联系人

UISS    用JSON的风格设置UIKit样式

Underscore.m    仿JS的underscore.js来写的,用于访问和处理数据

TICoreDataSync    在不同设备间对CoreData进行同步 (iPhone iPad Mac)

SoloComponents-iOS    几个轻量的组件,没什么用,2年没更新

MAObjCRuntime    将运行时包装成ObjC

Objective-C-Generics    通过宏定义勉强实现的范型

TBMacros    一些常用的宏定义

NSString-Ruby    为Ruby程序员带来的字符串相关功能

ObjectiveRecord    CoreData包装的活动记录 有RoR风格的API

FastImageCache    滑动时快速显示图片的库,Path开发

SketchUp 建筑草图大师 V5.0 正式版

软件类别:国产软件 / 免费软件 / 工程建筑

软件语言:简体中文

SketchUp5.0正式发布

@last创始人讲,“SketchUp5.0让你更快速的把你的设计理念付诸于3D表现”。

SketchUp 5.0引进了许多客户要求的新功能,包括新型的用户界面,加强了文件导入导出功能,并且增强对图形的运算能力,在曲面和地形的制作上有大的改善,以及加强了模型的管理功能。

功能概括:

1、 SketchUp操作界面

A、 重新设计了指示针及图标,现在它们看起来更容易被辨认;

B、 我们对工具栏做了进一步的改进,让工具栏和及图标更加的新颖和直观,并保留了远有简易性。

C、 5.0版本中整合了“窗口”栏下的设置选项,将一些原有设置栏有机组合在一起;方便参数的设置。同时,也有增强和扩充了键盘快捷键的设置,例:增加了ruby插件工具的键盘快捷件设置,同时也增加快捷件的查找等。

D、 对于SU的初学者,我们新增加了同步配置的教学指南,可供初学者学习。以及加强了网络互动连接。用户可以通过网络连接得到更多咨询信息(文字和视频教程);同时,用户也可以通过网络将一些建议、意见或问题通过@last在线用户反馈到总部,这些也将极大的提高问题解决的效率,同时也使我们的软件更加的完善。

2、 对话框状态

模型设置及管理会话框将可抓取屏幕边及应用窗口的边,同样会依附在其它边上(顶部或底部),生成会话框栈。

3、扩充管理器

扩充管理器可用于启动非常用的SketchUp功能,如sandbox工具。对于初次使用Sketchup常规命令的学者,扩充管理器帮助简化了sketchup的用户操作界面。

4、强大的新工具

Sandbox新工具体现在使您很简单的生成,建造地形或其它的由sandbox或TIN生成的有机形体,此工具不仅只能生成地形,也能用在生成有机的几何体或是看似手画的几何体,如木槽或是人物的表情。Sandbox工具通过sketchup的新扩充管理器来启用。”Sandbox”, 曲面和地形的制作工具栏。以下为该工具栏中的主要工具说明。

A、from contours (形体工具) :对等高线进行闭合来生成面,形成形体。

B、from scratch(网格工具) :绘制地形网格面(计算量最小的三角网格)

C、smoove(曲面拉伸) :对网格面进行曲面编辑,可用与制作山体等地形,也可用与制作一些如,雕塑、景观组建等非规则形体。

D、Stamp(曲面 ) : 在网格曲面上面拉伸制作形体,例如:在山体地形上面绘制房屋体形。

E、Drape(曲面投射) : 将你的曲面的地形上制作道路。

F、add detail(细化网格) : 对网格的局部或全部进行网格再细分 。

SketchUp就是一个相当简单却非常实用的工具,对现存的工具栏进行了很大规模性的改进后,使其建模能力更有威力。

5、真实的线条表现形式

SketchUp重要体现在从头至尾的设计构思过程中生成粗略、模糊及暂定的模型,看起来也比较像草图,我们通过增加以下功能扩充了简单的线条表现能力:

A、深度隐藏线段:让模型的边线根据景深而改变,增强作品真实性的同时,给予了作品的艺术感。

B、端点:强调线条的端点来以突出物体的棱角。

C、剖面:切边缘线,使其独立于外部形体。

D、透视图:支持放置的图像物及材质进行透视。

6、管理改进

新的管理目录用于以层次或树状结构的方式来浏览组件及群组。此功能在操纵大型模型时非常好用,重建模型结构,设置特殊组件的样例及重命名组件或群组。

SketchUp5中,增加了一些新功能帮助我们组织和管理模型,使其更容易利用组件达到最佳效果;

A、 管理目录给您的模型带来全新的亮点,以简单易用的组件管理浏览复杂的群组及组件;

B、 代替选择:允许你在画图区可用已选择好的组件替换被选择的组件,或修改整体的设计,以便更具体;

C、 防止修改误操作的疏忽及防止被移动或编辑, 可进行群组及组件的锁定;

D、 选择场景: