一.
数组
数组的创建 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
纯手打
正如你所知道的,ruby字符串被称为一流的对象,它使用了大量的查询和操作方法。一个最基本的字符串操作是把一个字符串分割成多个子字符串。如果你有一个字符串,如“foo, bar, baz”而你希望的是这样三个字符串“foo”,“bar”,“baz”。那么字符串类的split方法就可以帮助你。 “split”的基本用法 split方法的最基本用法分裂一个由单独字符或字符的静态序列组成的字符串。如果split的第一个变量是一个字符串,那么这个字符串中字符就会被当作一个字符串分隔符使用。但是在逗号分隔的数据中,逗号用来分隔数据,这里的每个字符串成分都被用来分隔数据。 #!/usr/bin/env rubystr =foo,bar,bazputsstr. split(,)$ ./1.rbfoobarbaz通过正则表达式来增加灵活性 当然,还有一些更容易的方法可以分隔字符串。正则表达式可以为split方法增加灵活性。这里再次拿“foo, bar, baz”。间隔在第一个逗号之后而不是第二个逗号。如果该字符串“,”被当成是分隔符,那么在“baz”字符串的开始处仍然会存在间隔。如果使用“,”字符串,它只与第一个逗号匹配,因为第二个逗号后面没有间隔。其作用还是有限的。 解决这个问题的办法是把正则表达式作为定界符的自变量,而不是使用字符串。正则表达式不仅可以匹配静态序列的字符,对字符的不定量和可选字符都同样起作用。 编写正则表达式 为你的分隔符编写一个正则表达式,第一步就是描述清楚什么是分隔符。在这种情况下,一个逗号后面可能存在一个或多个空格是合理的。这一正则表达式库中存在两个要素:逗号和可选的间隔。间隔会使用* (星号)量词,它表示的意思是“零或更多”。任何在它之前的要素都会匹配零次或若干次。例如,正则表达式/ a * /将匹配序列零或更多“a”字符。 #!/usr/bin/env rubystr =foo, bar,bazputsstr. split( /, */ )$ ./2.rbfoobarbaz限制splits的数量 想象一个逗号分隔了这样的字符串:“10,20,30,this is an arbitary string”。其格式是三个数字后面跟了一句评论。此评论可以包含任意的文本,包括带有逗号的文本。要防止split分离文本这个文本,我们可以设置一个最大分裂列数。请注意,只有在任意文本的评论字符串处在表格最后一列时才管用。 为了限制splits的数量,字符串中数域的数量要作为split方法的第二个变量来发送。 #!/usr/bin/env rubystr =10,20,30,ten, twenty and thirtyputsstr. split( /, */, 4 )$ ./3.rb102030en, twentyandthirty了解其局限性 分裂法有一些局限性。以字符串“10,20, ‘bob, eve and mallory’,30”为例。预期字符是两个数字,后跟一个引证串(可能包含逗号),然后是另一个数字。split不能正确分隔这个字符串的域。为了做到正确分隔,需要保持字符串扫描器处于开启状态,这样一来它就会记得它有没有在引证串内部。反之,如果扫描仪不在启动状态,就不能解决这样的问题。linux下ruby编程环境的安装和配置,方法如下:
1、去ruby官方下载安装包,下载地址:http://www.ruby-lang.org/en/downloads/
2、解压缩下载的ruby-1.9-stable.tar.gz安装包,进入目录。
su#./configure -prefix=/usr/local/ruby-1.9
#make
#make install
此时可能出现的错误:
echo executable host ruby is required. use --with-baseruby option.false ./tool/generic_erb.rb -c -o known_errors.inc
./template/known_errors.inc.tmpl ./defs/known_errors.def
executable host ruby is required. use --with-baseruby option.
make: *** [known_errors.inc] Error 1
出现此问题的原因在于1.9版本的ruby编译需要系统默认安装旧版本的ruby,而ubuntu中默认没有安装。
3、解决方法:
sudo apt-get install ruby#默认ubuntu10.10会自行安装ruby 1.8,之后再编译1.9就没问题了。
下载1.8.7版本源码编译安装,并设置临时环境变量 ,进入1.8源码目录
su#./configure -prefix=/usr/local/ruby-1.8
#make && make install
export PATH=/usr/local/ruby-1.8/bin:$PATH
#此时使用ruby -v验证版本为1.8
4、在刚才安装配置ruby1.8的终端中继续重新进行1.9的编译安装,进入1.9源码目录:
#解压文件tar vfxz ruby-1.9.1-p0.tar.gz
#进入解压后的文件夹
cd ruby-1.9.1-p0/
#编译源码,编译之前,应该先对/usr/local/ruby-1.9.1文件夹设置权限.
./configure --prefix=/usr/local/ruby-1.9.1
#大名鼎鼎的 make 和 install
make && make install
#设置PATH路径,把安装的ruby放在系统PATH前面,避免调用操作系统自带的ruby
export PATH=/usr/local/ruby-1.9.1/bin:$PATH
#在 ~/.profile 文件中增加了这样的代码:
if [ -d "/usr/local/ruby-1.9.1/bin" ] then
PATH="/usr/local/ruby-1.9.1/bin:$PATH"
fi
然后 注销 再登陆一次.
#如无意外
ruby -v
#ruby 1.9.1p0 (2009-01-30 revision 21907) [i686-linux]
#ruby 1.9.1安装成功了.
注意:之前安装了1.8版本ruby,可以直接通过rm -rf /usr/local/ruby-1.8删除即可。