\a 替换成Bell声所对应的符号
\nnn nnn表示一个八进制数值,替换成该八进制所对应的字符
\b 退格符,替换成退格键所对应的字符
\xnn xnn表示一个十六进制数,替换成该十六进制数所对应的字符
\e 替换成Escape键对应的字符
\cx替换成Ctrl+X组合键对应的字符,其中x可以是任意键对应的字符
\C-x 替换成Ctrl+X组合键对应的字符,其中x可以是任意键对应的字符
\n 换行符,替换成一个空行
\M-x 替换成Alt+X组合键对应的字符,其中x可以是任意键对应的字符
\r 回车符,替换成一个回车
\M-\C-x 替换成Ctrl+Alt+X组合键对应的字符,其中x可以是任意键对应的字符
\s 空白符,替换成一个空白字符
\t 替换成一个Tab键所对应的字符
\v 替换成一个垂直Tab键所对应的字符
#{expr}替换成变量或者表达式expr所对应的值
一.
数组
数组的创建 names = ["shiwanyin","jingshang","dapao","xishuai"]
数组对象 数组对象未确定时,用[]表示一个空数组对象。
从数组中抽取对象 names[0]
print "第一个名字为:",names[0],"。\n"
将对象保存到数组中 支持多种不同对象的混合保存。
数组的大小
array.size
数组的循环
names.each do |变量|
希望循环的处理
end
15散列类
15.1复习散列
15.2散列的创建
15.2.1使用{}
{键=>值}
像下面那样指定键值对,键值对之间用逗号,隔开
h1 = {"a"=>"b","c"=>"d"}
p h1["a"] #=>"b"
用符号作为键时
{键:值}
h2 = {a:"b",c:"d"}
p h2 #=>{:a=>"b",:c=>"d"}
15.2.2使用Hash.new
用来创建新的散列的方法。
指定参数值返回
15.3 值的获取与设定
与数组一样,散列也是用[]来实现与键相对应的元素值的获取与设定的。
h = Hash.new
h["R"] = "Ruby"
p h["R"] #=>"Ruby"
还可以用store方法设定值,用fetch方法获取值。下面的例子的执行结果与上面的例子是一样的。
h = hash.new
h.store("R","Ruby")
p h.fetch("R") #=>"Ruby"、(如果散列中不存在指定的键,程序就会发生异常)
对fetch方法指定第二个参数,那么该参数值就会作为键不存在是散列的默认值。
h = Hash.new
p h.fetch("N"){String.new} #=>""
15.3.1
一次性获取所有的键值。由于散列是键值对形式的数据类型,因此获取键值的方法是分开的。
h = {"a" = "b","c" = "d"}
p h.keys #=>["a","c"]
p h.values #=>["b","d"]
p h.to_a #=>[["a","b"],["c","d"]]
除了返回数组,使用迭代器获取散列值。
Number无需声明
字符串类
14.1字符串的创建
str1 = "字符串";str2 = '字符串'。
使用“”时可以执行用#{}括起来的Ruby式子。 这个#{}就称为内嵌表达式。
14.1.1 %Q和%q
创建包含“‘的字符串,使用%Q或者%q会比使用\" \'更简单
desc = %Q{Ruby的字符串中也可以使用’‘和”“} %Q相当于用“”创建字符串
str = %q|Ruby said, 'Hello world' %q相当于用‘’创建字符串
14.1.2
使用Here Document
Here Document 是源自于Unix的shell的一种程序写法。
使用<<创建字符串(创建包含换行的长字符串时这个方法是最简单的)
<<"结束标识符"
字符串内容
结束标识符
<<后面的结束标识符可以用“”括着的字符串(转义字符和内嵌表达式)或者用‘’括着的字符串定义(原封不动的显示)。
Here Document 的结束标识符一定要在行首。在程序缩进较深的地方会出现缩进乱掉的情况。
使用<<- 代替 <<,忽略掉结束标识符前的空格和制表符。结束标识符就没有必要写在行首。
range类
r1=1..5 #定义范围对象r1,包括元素1,2,3,4,5
r2=Range.new(1,5) #等价与1..5
r3=1...5 #定义范围对象r3,包括元素2,3,4
r4=Range.new(1,5,true) #等价与1...5
二。循环
1. times方法
在前面已经有提到过了,语法如下:
复制代码 代码如下:
循环次数.times do 循环次数.times {
重复执行的动作 重复执行的动作
end }
#也可以在times模块中加入变量
5.times { |i|
print "This is the", i+1, " time. \n"
}
# i变量是从0开始计算的
2. for 语句
复制代码 代码如下:
语法:
for 变量 in 开始数值..结束数值 do
反复执行的动作
end
# do是可以省略的
from = 0
to = 20
sum = 0
for i in from..to
sum += 1
end
语法:
for 变量 in 对象
反复执行的动作
end
names = ["Windy", "Cindy", "Jack", "Hugo"]
for name in names
print name, " likes Ruby. \n"
end
第二个语法的for语句,与java中的for each语句非常类似,for (i in list?) {...}
3. while 语句
while语句与JAVA中也是类似的
复制代码 代码如下:
语法:
while 条件 do
反复执行的动作
end
a = 1
sum = 0
while a <10 do
sum += a
i += a
end
4. until 语句
其语法与while语句类似,只是只有条件不符合的时候,才会反复执行循环
复制代码 代码如下:
语法:
until 条件 do
反复执行的动作
end
# do可以省略
sum = 0
until sum >50
sum += 1
end
print sum
# 以上until循环可以转换成下面的while循环
while !(sum >50)
sum += 1
end
5. each 方法
在前面已经提到过这个方法了,这里就简要记录下语法
复制代码 代码如下:
对象.each { |变量|
想要反复执行的动作
}
6. loop方法
它是一种没有结束条件的方法,只是不断进行循环处理,示例如下:
复制代码 代码如下:
loop {
print "Ruby"
}
三。运算符
算术运算符+-*/ 取余% 平方**
比较运算符 >,<,==,!=,>=,<=,===,<=>,.eql?,equal?(区别最后两个) 前者是判断两个数值是否相同,后者是判断是否为同一个数,如果不懂可以继续追问我。
四。正则表达式 这一部分应该是ruby的特色,建议你好好学学。推荐这个地址给你
http://www.runoob.com/ruby/ruby-regular-expressions.html
纯手打
file = File.new(“testfile”, “r”)# … process the filefile.closetestfile是想要操作的文件名,”r”说明了文件的操作模式为读取。可以使用”w”表示写入,”rw”表示读写。最后要记得关闭打开的文件,确保所有被缓冲的数据被写入文件,所有相关的资源被释放。也可以使用File.open来打开文件,open和new的不同是open可以使用其后的代码块而new方法则返回一个File类的实例。File.open(“testfile”, “r”) do |file|# … process the fileendopen操作的另一个优点是处理了异常,如果处理一个文件发生错误抛出了异常的话,那么open操作会自动关闭这个文件,下面是open操作的大致实现:class Filedef File.open(*args)result = f = File.new(*args)if block_given?beginresult = yield fensuref.closeendendreturn resultendend对于文件的路径,Ruby会在不同的操作系统间作转换。例如,在Windows下,/ruby/sample/test.rb会被转化为\ruby\sample\test.rb。当你使用字符串表示一个Windows下的文件时,请记住使用反斜线先转义: