NCF参数化建筑论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

搜索
查看: 19716|回复: 172

[相关书籍] RhinoScript语法(入门基础2)

  [复制链接]
发表于 2009-8-28 19:16:23 | 显示全部楼层 |阅读模式
游客,如果您要查看本帖隐藏内容请回复

使用循环语句
       使用循环重复执行代码
       循环用于重复执行一组语句。循环可分为三类:一类在条件变为 False 之前重复执行语句,一类在条件变为 True 之前重复执行语句,另一类按照指定的次数重复执行
语句。
       在VBScript 中可使用下列循环语句:
       * Do...Loop: 当(或直到)条件为 True 时循环。
       * While...Wend: 当条件为 True 时循环。
       * For...Next: 指定循环次数,使用计数器重复运行语句。
       * For Each...Next: 对于集合中的每项或数组中的每个元素,重复执行一组语句。
       使用 Do 循环
       可以使用 Do...Loop 语句多次(次数不定)运行语句块。当条件为 True 时或条件变为 True 之前,重复执行语句块。
       当条件为 True 时重复执行语句
       While 关键字用于检查 Do...Loop 语句中的条件。有两种方式检查条件:在进入循环之前检查条件(如下面的 ChkFirstWhile 示例);或者在循环至少运行完一次之后
检查条件(如下面的 ChkLastWhile 示例)。在 ChkFirstWhile 过程中,如果 myNum 的初始值被设置为 9 而不是 20,则永远不会执行循环体中的语句。在
ChkLastWhile 过程中,循环体中的语句只会执行一次,因为条件在检查时已经为 False。
      Sub ChkFirstWhile()
      Dim counter, myNum
      counter = 0
      myNum = 20
      Do While myNum > 10
      myNum = myNum - 1
      counter = counter + 1
      Loop
      MsgBox "循环重复了 " & counter & " 次。"
      End Sub
      Sub ChkLastWhile()
      Dim counter, myNum
      counter = 0
      myNum = 9
      Do
      myNum = myNum - 1
      counter = counter + 1
      Loop While myNum > 10
      MsgBox "循环重复了 " & counter & " 次。"
      End Sub
     重复执行语句直到条件变为 True
     Until 关键字用于检查 Do...Loop 语句中的条件。有两种方式检查条件:在进入循环之前检查条件(如下面的 ChkFirstUntil 示例);或者在循环至少运行完一次之后检
查条件(如下面的 ChkLastUntil 示例)。只要条件为 False,就会进行循环。
     Sub ChkFirstUntil()
     Dim counter, myNum
     counter = 0
     myNum = 20
     Do Until myNum = 10
     myNum = myNum - 1
     counter = counter + 1
     Loop
     MsgBox "循环重复了 " & counter & " 次。"  
     End Sub
     Sub ChkLastUntil()
     Dim counter, myNum
     counter = 0
     myNum = 1
     Do myNum = myNum + 1
     counter = counter + 1
     Loop Until myNum = 10
     MsgBox "循环重复了 " & counter & " 次。"
     End Sub
     退出循环
     Exit Do 语句用于退出 Do...Loop 循环。因为通常只是在某些特殊情况下要退出循环(例如要避免死循环),所以可在 If...Then...Else 语句的 True 语句块中使用 Exit Do
语句。如果条件为 False,循环将照常运行。
     在下面的示例中,myNum 的初始值将导致死循环。If...Then...Else 语句检查此条件,防止出现死循环。
     Sub ExitExample()
     Dim counter, myNum
     counter = 0
     myNum = 9
     Do Until myNum = 10
     myNum = myNum - 1
     counter = counter + 1
     If myNum < 10 Then Exit Do
     Loop
     MsgBox "循环重复了 " & counter & " 次。"
     End Sub
    使用 While...end
    While...end 语句是为那些熟悉其用法的用户提供的。
    但是由于 While...Wend 缺少灵活性,所以建议最好使用 Do...Loop 语句。
    For...Next 语句用于将语句块运行指定的次数。在循环中使用计数器变量,该变量的值随每一次循环增加或减少。
    例如,下面的示例将过程 MyProc 重复执行 50 次。For 语句指定计数器变量 x 及其起始值与终止值。Next 语句使计数器变量每次加 1。
    Sub DoMyProc50Times()
    Dim x
    For x = 1 To 50
    MyProc Next
    End Sub
    关键字 Step 用于指定计数器变量每次增加或减少的值。在下面的示例中,计数器变量 j 每次加 2。循环结束后,total 的值为 2、4、6、8 和 10 的总和。
    Sub TwosTotal()
    Dim j, total
    For j = 2 To 10 Step 2
    total = total + j
    Next MsgBox "总和为 " & total & "。"
    End Sub
    要使计数器变量递减,可将 Step 设为负值。此时计数器变量的终止值必须小于起始值。在下面的示例中,计数器变量 myNum 每次减 2。循环结束后,total 的值为 16
、14、12、10、8、6、4 和 2 的总和。
   
   Sub NewTotal()
   Dim myNum, total
   For myNum = 16 To 2 Step -2
   total = total + myNum
   Next
   MsgBox "总和为 " & total & "。"
   End Sub
发表于 2009-9-7 03:01:22 | 显示全部楼层
太感謝了 真是不可多得的教材....
发表于 2009-10-21 14:17:04 | 显示全部楼层
呵呵
焊好很强大!
看这个能不能学会哦?
发表于 2009-10-29 18:17:26 | 显示全部楼层
非常感谢,难得的好教材
发表于 2009-10-30 16:42:59 | 显示全部楼层
很不错的教材{:3_53:}
发表于 2009-11-6 14:46:04 | 显示全部楼层
载下来慢慢研究  嘿嘿 学习了
发表于 2009-11-10 14:07:01 | 显示全部楼层
刚看完一,头还晕乎晕乎呢,先坚持把二看了。再次感谢楼主。
发表于 2009-11-22 14:11:30 | 显示全部楼层
vb.net和vb还是有蛮大区别的 不过这个基本的vb语法确实是script必须的
发表于 2009-12-11 17:19:54 | 显示全部楼层
感谢 f(x) 大大 这么好的东西~
发表于 2009-12-11 18:19:36 | 显示全部楼层
一在那里??
发表于 2010-1-6 13:00:36 | 显示全部楼层
继续学习!!!!
发表于 2010-1-10 21:31:40 | 显示全部楼层
谢谢楼主{:3_53:}
发表于 2010-1-18 11:09:57 | 显示全部楼层
难得一见的教材
发表于 2010-1-18 12:05:37 | 显示全部楼层
看完了1 ,又来关注2 了...哈...
发表于 2010-1-28 20:44:25 | 显示全部楼层
顺着1来的看看
发表于 2010-3-7 23:12:57 | 显示全部楼层
看完一接着看二~~爽!
发表于 2010-3-9 20:08:17 | 显示全部楼层
谢谢啦很好的东西
发表于 2010-3-9 20:49:54 | 显示全部楼层
感谢感谢好东西好东西
发表于 2010-3-14 10:39:23 | 显示全部楼层
你牛逼的很~!!呵呵
发表于 2010-3-22 16:29:02 | 显示全部楼层
多谢多谢啊

手机版|NCF参数化建筑论坛 ( 辽ICP备12011358号-1 )   辽公网安备 21020302000097号

GMT+8, 2018-11-22 04:11 , Processed in 0.262029 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表