zoukankan      html  css  js  c++  java
  • ASP操作Excel技术总结

    ASP操作Excel技术总结

    目录
    一、  环境配置
    二、  ASP对Excel的基本操作
    三、  ASP操作Excel生成数据表
    四、  ASP操作Excel生成Chart图
    五、  服务器端Excel文件浏览、下载、删除方案
    六、  附录

    正文
    一、  环境配置
    服务器端的环境配置从参考资料上看,微软系列的配置应该都行,即:
    1.Win9x+PWS+Office
    2.Win2000 Professional+PWS+Office
    3.Win2000 Server+IIS+Office
    目前笔者测试成功的环境是后二者。Office的版本没有特殊要求,考虑到客户机配置的不确定性和下兼容特性,建议服务器端Office版本不要太高,以防止客户机下载后无法正确显示。
    服务器端环境配置还有两个偶然的发现是:
    1.  笔者开发机器上原来装有金山的WPS2002,结果Excel对象创建始终出现问题,卸载WPS2002后,错误消失。
    2.  笔者开发ASP代码喜欢用FrontPage,结果发现如果FrontPage打开(服务器端),对象创建出现不稳定现象,时而成功时而不成功。扩展考察后发现,Office系列的软件如果在服务器端运行,则Excel对象的创建很难成功。
    服务器端还必须要设置的一点是COM组件的操作权限。在命令行键入“DCOMCNFG”,则进入COM组件配置界面,选择Microsoft Excel后点击属性按钮,将三个单选项一律选择自定义,编辑中将Everyone加入所有权限。保存完毕后重新启动服务器。
    客户端的环境配置没发现什么特别讲究的地方,只要装有Office和IE即可,版本通用的好象都可以。

    二、  ASP对Excel的基本操作
    1、  建立Excel对象
    set objExcelApp = CreateObject("Excel.Application")
    objExcelApp.DisplayAlerts = false    不显示警告
    objExcelApp.Application.Visible = false    不显示界面
    2、  新建Excel文件
    objExcelApp.WorkBooks.add
    set objExcelBook = objExcelApp.ActiveWorkBook
    set objExcelSheets = objExcelBook.Worksheets
    set objExcelSheet = objExcelBook.Sheets(1)
    3、  读取已有Excel文件
    strAddr = Server.MapPath(".")
    objExcelApp.WorkBooks.Open(strAddr & "\Templet\Table.xls")
    set objExcelBook = objExcelApp.ActiveWorkBook
    set objExcelSheets = objExcelBook.Worksheets
    set objExcelSheet = objExcelBook.Sheets(1)
    4、  另存Excel文件
    objExcelBook.SaveAs strAddr & "\Temp\Table.xls"
    5、  保存Excel文件
    objExcelBook.Save    (笔者测试时保存成功,页面报错。)
    6、  退出Excel操作
    objExcelApp.Quit  一定要退出
    set objExcelApp = Nothing

    三、  ASP操作Excel生成数据表
    1、  在一个范围内插入数据
    objExcelSheet.Range("B3:k3").Value = Array("67", "87", "5", "9", "7", "45", "45", "54", "54", "10")
    2、  在一个单元格内插入数据
    objExcelSheet.Cells(3,1).Value="Internet Explorer"
    3、  选中一个范围
    4、  单元格左边画粗线条
    5、  单元格右边画粗线条
    6、  单元格上边画粗线条
    7、  单元格下边画粗线条
    8、  单元格设定背景色
    9、  合并单元格
    10、  插入行
    11、  插入列

    四、  ASP操作Excel生成Chart图
    1、  创建Chart图
    objExcelApp.Charts.Add
    2、  设定Chart图种类
    objExcelApp.ActiveChart.ChartType = 97
    注:二维折线图,4;二维饼图,5;二维柱形图,51
    3、  设定Chart图标题
    objExcelApp.ActiveChart.HasTitle = True
    objExcelApp.ActiveChart.ChartTitle.Text = "A test Chart"
    4、  通过表格数据设定图形
    objExcelApp.ActiveChart.SetSourceData objExcelSheet.Range("A1:k5"),1
    5、  直接设定图形数据(推荐)
    objExcelApp.ActiveChart.SeriesCollection.NewSeries
    objExcelApp.ActiveChart.SeriesCollection(1).Name = "=""333"""
    objExcelApp.ActiveChart.SeriesCollection(1).Values = "="
    6、  绑定Chart图
    objExcelApp.ActiveChart.Location 1
    7、  显示数据表
    objExcelApp.ActiveChart.HasDataTable = True
    8、  显示图例
    objExcelApp.ActiveChart.DataTable.ShowLegendKey = True

    五、  服务器端Excel文件浏览、下载、删除方案
    浏览的解决方法很多,“Location.href=”,“Navigate”,“Response.Redirect”都可以实现,建议用客户端的方法,原因是给服务器更多的时间生成Excel文件。
    下载的实现要麻烦一些。用网上现成的服务器端下载组件或自己定制开发一个组件是比较好的方案。另外一种方法是在客户端操作Excel组件,由客户端操作服务器端Excel文件另存至客户端。这种方法要求客户端开放不安全ActiveX控件的操作权限,考虑到通知每个客户将服务器设置为可信站点的麻烦程度建议还是用第一个方法比较省事。
    删除方案由三部分组成:
    A:  同一用户生成的Excel文件用同一个文件名,文件名可用用户ID号或SessionID号等可确信不重复字符串组成。这样新文件生成时自动覆盖上一文件。
    B:  在Global.asa文件中设置Session_onEnd事件激发时,删除这个用户的Excel暂存文件。
    C:  在Global.asa文件中设置Application_onStart事件激发时,删除暂存目录下的所有文件。
    注:建议目录结构 \Src 代码目录 \Templet 模板目录 \Temp 暂存目录

    六、  附录
    出错时Excel出现的死进程出现是一件很头疼的事情。在每个文件前加上“On Error Resume Next”将有助于改善这种情况,因为它会不管文件是否产生错误都坚持执行到“Application.Quit”,保证每次程序执行完不留下死进程。

    posted on 2005-03-08 17:07 爬行的E.T 阅读(6) 评论(1) 编辑 收藏

    评论

    re: ASP操作Excel技术总结

    这个程序一共由三个文件构成,第一个文件的文件名为:toexcel.asp是主文件,内容如下:

    <%

    '前面是和来链接到数据库,请自行书写相关语句,此处略过

    sql="select * from [tx_use]" '这里是要输出EXCEL的查询语句,如 "SESECT * FORM CAI WHERE 性别='女'"
    filename="excel.xls" ' 要输出的EXCEL文件的文件名, 你只要改以上两句就行了,其它的都不要改.

    '你只要修改以上两变量就行了.其它的我都做好了.

    call toexcel(FILENAME,sql)
    set conn=nothing

    function ReadText(FileName) '这是一个用于读出文件的函数
    set adf=server.CreateObject("Adodb.Stream")
    with adf
    .Type=2
    .LineSeparator=10
    .Open
    .LoadFromFile (server.MapPath(FileName))
    .Charset="GB2312"
    .Position=2
    ReadText=.ReadText
    .Cancel()
    .Close()
    end with
    set ads=nothing
    end function

    sub SaveText(FileName,Data) '这是一个用于写文件的函数
    set fs= createobject("scripting.filesystemobject")
    set ts=fs.createtextfile(server.MapPath(FileName),true)
    ts.writeline(data)
    ts.close
    set ts=nothing
    set fs=nothing
    end sub

    sub toexcel(filename,sql) '这是一个根据SQL语句和FILENAME生成EXCEL文件
    Set rs=Server.CreateObject("ADODB.RecordSet")
    rs.Open sql,conn,1,3
    TOEXCELLR="

    "
    set myfield=rs.fields
    dim fieldname(50)
    for i=0 to myfield.count-1
    toexcellr=toexcellr&""
    fieldname(i)=myfield(i).name
    if myfield(i).type=135 then datename=datename&myfield(i).name&","
    next
    toexcellr=toexcellr&""
    do while not rs.eof
    toexcellr=toexcellr&""
    for i=0 to myfield.count-1
    if instr(datename,fieldname(i)&",")<>0 then
    if not isnull(rs(fieldname(i))) then
    TOEXCELLR=TOEXCELLR&""
    else
    TOEXCELLR=TOEXCELLR&""
    end if
    else
    TOEXCELLR=TOEXCELLR&""
    end if
    next
    toexcellr=toexcellr&""
    rs.movenext
    loop
    toexcellr=toexcellr&"
    "&MYFIELD(I).NAME&"

    "&formatdatetime(rs(fieldname(i)),2)&"

     

    "&rs(fieldname(i))&"
    "
    tou=readtext("tou.txt")
    di=readtext("di.txt")
    toexcellr=tou&toexcellr&di
    call savetext(filename,toexcellr)
    end sub
    %>

    正在生成EXLCE文件 正在生成EXLCE文件....

    **************第二个文件名为:di.txt 内容如下:

    ************第三个文件的文件名为:tou.TXT 内容如下:

    <head> <meta http-equiv=Content-Type content="text/html; charset=GB2312"> <meta name=ProgId content=Excel.Sheet> <meta name=Generator content="Microsoft Excel 9"> <link rel=File-List href="./222.files/filelist.xml"> <link rel=Edit-Time-Data href="./222.files/editdata.mso"> <link rel=OLE-Object-Data href="./222.files/oledata.mso"> <!--[if gte mso 9]><xml> <DocumentProperties> <Author>xky</Author> <LastAuthor>xky</LastAuthor> <Created>2002-05-27T17:51:00Z</Created> <LastSaved>2002-06-22T10:03:03Z</LastSaved> <Company>zydn</Company> <Version>9.2812</Version> </DocumentProperties> <OfficeDocumentSettings> <DownloadComponents/> <LocationOfComponents HRef="file:///E:/msowc.cab"/> </OfficeDocumentSettings> </xml><![endif]--> <style> <!--table {mso-displayed-decimal-separator:"\."; mso-displayed-thousand-separator:"\,";} @page {margin:1.0in .75in 1.0in .75in; mso-header-margin:.5in; mso-footer-margin:.5in;} tr {mso-height-source:auto; mso-ruby-visibility:none;} col {mso-width-source:auto; mso-ruby-visibility:none;} br {mso-data-placement:same-cell;} .style0 {mso-number-format:General; text-align:general; vertical-align:bottom; white-space:nowrap; mso-rotate:0; mso-background-source:auto; mso-pattern:auto; color:windowtext; font-size:9.0pt; font-weight:400; font-style:normal; text-decoration:none; font-family:宋体; mso-generic-font-family:auto; mso-font-charset:134; border:none; mso-protection:locked visible; mso-style-name:常规; mso-style-id:0;} td {mso-style-parent:style0; padding-top:1px; padding-right:1px; padding-left:1px; mso-ignore:padding; color:windowtext; font-size:9.0pt; font-weight:400; font-style:normal; text-decoration:none; font-family:宋体; mso-generic-font-family:auto; mso-font-charset:134; mso-number-format:General; text-align:general; vertical-align:bottom; border:none; mso-background-source:auto; mso-pattern:auto; mso-protection:locked visible; white-space:nowrap; mso-rotate:0;} .xl24 {mso-style-parent:style0; border:.5pt solid windowtext;} .xl25 {mso-style-parent:style0; mso-number-format:"Long Date"; text-align:left; border:.5pt solid windowtext;} ruby {ruby-align:left;} rt {color:windowtext; font-size:9.0pt; font-weight:400; font-style:normal; text-decoration:none; font-family:宋体; mso-generic-font-family:auto; mso-font-charset:134; mso-char-type:none; display:none;} --> </style> <!--[if gte mso 9]><xml> <x:ExcelWorkbook> <x:ExcelWorksheets> <x:ExcelWorksheet> <x:Name>Sheet1</x:Name> <x:WorksheetOptions> <x:DefaultRowHeight>225</x:DefaultRowHeight> <x:Print> <x:ValidPrinterInfo/> <x:PaperSizeIndex>9</x:PaperSizeIndex> <x:HorizontalResolution>-3</x:HorizontalResolution> <x:VerticalResolution>0</x:VerticalResolution> </x:Print> <x:Selected/> <x:Panes> <x:Pane> <x:Number>3</x:Number> <x:ActiveRow>24</x:ActiveRow> <x:ActiveCol>5</x:ActiveCol> </x:Pane> </x:Panes> <x:ProtectContents>False</x:ProtectContents> <x:ProtectObjects>False</x:ProtectObjects> <x:ProtectScenarios>False</x:ProtectScenarios> </x:WorksheetOptions> </x:ExcelWorksheet> <x:ExcelWorksheet> <x:Name>Sheet2</x:Name> <x:WorksheetOptions> <x:DefaultRowHeight>225</x:DefaultRowHeight> <x:ProtectContents>False</x:ProtectContents> <x:ProtectObjects>False</x:ProtectObjects> <x:ProtectScenarios>False</x:ProtectScenarios> </x:WorksheetOptions> </x:ExcelWorksheet> <x:ExcelWorksheet> <x:Name>Sheet3</x:Name> <x:WorksheetOptions> <x:DefaultRowHeight>225</x:DefaultRowHeight> <x:ProtectContents>False</x:ProtectContents> <x:ProtectObjects>False</x:ProtectObjects> <x:ProtectScenarios>False</x:ProtectScenarios> </x:WorksheetOptions> </x:ExcelWorksheet> </x:ExcelWorksheets> <x:WindowHeight>6600</x:WindowHeight> <x:WindowWidth>12000</x:WindowWidth> <x:WindowTopX>0</x:WindowTopX> <x:WindowTopY>1395</x:WindowTopY> <x:ProtectStructure>False</x:ProtectStructure> <x:ProtectWindows>False</x:ProtectWindows> </x:ExcelWorkbook> </xml><![endif]--> </head>

    liujun999999,2005-04-04 14:05:55

    很久之前有人发过了

    eniac,2005-04-04 15:47:33

    引用:http://twct.com/blogview.asp?logID=108

    VBS编程教程

    发现大部分黑白的朋友都不会编程, 这可不是件好事, 所以这次我就写了一个简单的编程教程, 讲一下VBScript. 主要面向菜鸟, 懂得编程的朋友就不要浪费时间了, 如果你想接触以下VBScript也可以, 但既然有编程基础推荐直接去找一些参考书来读, 会比较快.

    什么是VBScript呢? VBScript的全称是:Microsoft Visual Basic Script Editon.(微软公司可视化BASIC脚本版). 正如其字面所透露的信息, VBS(VBScript的进一步简写)是基于Visual Basic的脚本语言. 我进一步解释一下, Microsoft Visual Basic是微软公司出品的一套可视化编程工具, 语法基于Basic. 脚本语言, 就是不编译成二进制文件, 直接由宿主(host)解释源代码并执行, 简单点说就是你写的程序不需要编译成.exe, 而是直接给用户发送.vbs的源程序, 用户就能执行了. 
    

      我知道菜鸟现在最关心的就是用什么工具来开发VBS程序了, 答案是:记事本(Notepad).我不是开玩笑, 其实任何一种文本编辑器都可以用来开发VBS开发, 只不过记事本是由系统自带的, 比较好找而已. 尽管如此, 我还是建议你去下载一个专业的文本编辑器, 因为这些工具可以提供 "语法高亮"等功能, 更加方便开发, 用哪一个随你喜好, 我比较喜欢Edit Plus (2.10).

      OK, 我们先来写一个VBScript程序热热身.

    REM 输入并回显你的名字
    ’使用InputBox和Msgbox函数
    Dim name,msg
    msg="请输入你的名字:"
    name=Inputbox(msg,"名称")
    Msgbox(name)

      把上面的程序清单输入到记事本里面, 然后保存为以.vbs为扩展名的文件("保存类型"里面选择"所有文件").然后双击运行, 观察运行结果. 注意:请自己输入程序清单, 不要复制->粘贴!

      我来解释一下这个程序, 第一行和第二行的开头分别是"REM"语句和" ’ ", 这两个东西的作用是相同的, 表示本行是注释行, 就是说这两行什么也不干,只是用来说明这段程序的功能, 版权信息等等. 注释行是程序最重要的部分之一, 尽管它不是必需的, 但对于其他人阅读源代码, 以及自己分析源代码是很有好处的. 好的习惯是在必要的地方加上清晰, 简洁的注释.

      Dim用来声明一个变量, 在VBS中, 变量类型并不是那么重要, 就是说VBS会帮你自动识别变量类型, 而且变量在使用前不一定要先声明, 程序会动态分配变量空间. 在VBS中你不用考虑name储存的是一个整数还是一个小数(学名叫"浮点数"), 也不用考虑是不是字符串(一串字符, 比如:"Hello World"), VBS会自动帮你搞定. 所以第三行语句可以删除, 效果不会变, 但我强烈反对这么做, 一个变量的基本原则就是:先声明,后使用.变量名用字母开头,可以使用下划线,数字, 但不能使用vbs已经定义的字, 比如dim, 也不能是纯数字.

      下一行被称之为"赋值", "="是赋值符号, 并不是数学中的等于号, 尽管看起来一样.这是正统的理解, 你要理解成等于也没有什么不可. 赋值号的左边是一个变量, 右边是要赋给变量的值, 经过赋值以后, msg这个变量在程序中等同于"请输入你的名字:"这个字符串,但当msg被再次复制的时候, 原值就会消失. 不光字符串, 其他任何变量都这样被赋值, 例如: a=2, b=12.222等等.

      再往下,Inputbox和Msgbox是VBS内建的函数, 一个函数就相当于一个"黑箱", 有输入(参数)和输出(返回值), 你可以不用了解函数是怎么运作的, 只要了解这个函数能干什么就行了, 我们也可以定义自己的函数, 不过那要等到以后再讲. 现在我们只要了解, 一个函数可以有返回值也可以没有, 可以有参数也可以没有. 例如Inputbox就是有返回值的函数, 我们用赋值号左边的变量来"接"住InputBox的返回值--就是你输入的内容. 在inputbox右边的括号里是参数列表, 每个参数用","分隔开, 每个参数有不同的功效, 比如第一个参数会显示在提示里, 我们把msg这个变量作为第一个参数传给了Inputbox 函数, 而msg="请输入你的名字:", 所以我们在对话框的提示栏就会看到"请输入你的名字:" 第二个参数是对话框的标题, 我们用直接量(学名叫"常量", 这里是"字符串常量")传递给函数, 当然你也可以传递变量. Inputbox还有很多参数, 比如你在"名称"后面再加一个","然后输入随便一串字符(字符串,用双引号""包裹起来的一串字符叫做字符串)然后运行, 看看结果. 你会发现用于输入的文本框有了默认的值, 这就是第三个参数的作用.

      Msgbox函数是用来输出的函数, 在VBS中没有专门的输出函数(BASIC中的print,C中的printf), 所以我们只能用对话框来观察输出结果, Msgbox的必要参数只有一个, 就是要输出的内容, 在这种情况下, 我们不需要理会msgbox的返回值. 关于Msgbox和Inputbox我们以后还会在讨论, 今天只是热热身, 到此为止.

    要点:

    1. 注释(以REM或’开头)行在程序中不起作用, 但能让别人更容易读懂你的程序.

    2. 变量好像一个盒子, 或一个代号, 可以代表你想代表的东西. 变量赋值使用"="

    3. 以""包裹起来的字符称之为"字符串"

    4. 函数像一个"黑箱", 有参数和返回值, 用"="左边的变量可以接住返回值

    5. Inputbox函数弹出一个输入对话框,Msgbox则用于输出

    作业:

    1. 试验Inputbox的第三个参数

    2. 写一段程序输出你的年龄

    3. 写一段程序进行3次输入, 分别输入你和你父母的姓名(要求显示提示), 并分3次输出
      第二篇:

      我真没想到, 第一次的作业竟然有人不会. 
      

      看来要讲的非常非常细致才行, 嗯, 今天讲各种"量"和基本运算

      先说常量, 这个比较简单.

      什么是常量呢, 常量就是其值不可变化的量.

      常量分为两种:第一种, 自然常量. 这叫是因为它们本身就是常量, 你怎么更改21的值呢? 他永远都是21, 不可能变成46

    如果你在程序中使用"21=46", 这样的语句将会引发一个错误. 同样的, 字符串也是常量 (还记得字符串吗? 就是包裹在""之间的一串字符), "Hello World"就是一个例子, 如果你使用"Hello World"="Bye"这样的语句同样会引发一个错误. 你能举出自然常量的更多例子吗? 
    

      第二种, 是我们自己定义的常量,这种量也使用代号, 他们也被赋值, 但和变量的不同点在于, 他们在定义的时候被赋值,以后就不能改变了,如果企图改变将会引发一个错误. 定义一个变量,我们使用"const"这个关键字(关键字的意思是系统定义了有特殊功能的字, 不能作为变量名或常量名使用),格式是:const 常量名=常量值.

    例如: 
    

    const PI=3.1415926

    const NAME="记忆碎片"

      这样我们就定义了两个常量, PI和NAME, 一般说来, 常量名全部使用大写, 但也可以不用, 随你喜好. 将一些在程序中不需要改变的值定义为常量是个好习惯, 这样能防止不必要的意外. 另外, 使用自定义常量也可以减少你的工作量. 比如:

    msgbox("Hello World")
    msgbox("Hello World")
    msgbox("Hello World")
    msgbox("Hello World")
    msgbox("Hello World")

      这个程序输出五次Hello World, 如果你想要改变输出为Bye-Bye, 就必须修改全部程序, 当然你可以手动修改5次, 但如果你要输出1000次呢? 常量就可以替我们解决这个问题:

    const hw="Hello World"
    msgbox(hw)
    msgbox(hw)
    msgbox(hw)
    msgbox(hw)
    msgbox(hw)

      这样当你要修改输出的时候只要修改hw的值就行了.

      好了, 现在我们来看看编程的第一块重要"基石":变量. 解释变量最好的办法我觉得是"盒子", 一个变量好像一个盒子, 里面只能装一个东西, 当你要装进去别的东西的时候必须把原有的东西拿出来. 这个"盒子"是有名称的, 当你在程序中使用变量的时候, 系统会打开盒子取出里面的东西, 让这些东西参与处理, 而不是盒子. 有些语言是很依赖"盒子"里面装些什么东西, 这样才能找到合适的"盒子"(比如C语言), 但VBS给我提供的是能够自动伸缩的"魔术盒", 我们不用关心装进去的是什么东西,

    VBS会自动调整盒子的大小. 例如:

    Dim a1,a2,a3
    a1=14
    a2=12.23
    a3="Hello"

    而不用像C语言那样麻烦: 或者是VB的正规声明(VB可以声明也可以不用)那样:

    int a1; Dim a1 as integer
    float a2; Dim a2 as Double
    char* a3; Dim a3 as strnig
    a1=14; a1=14
    a2=12.23; a2=12.23
    a3="Hello"; a3="Hello"

    嗯……扯远了……

      变量有什么用呢? 哇, 那用处可大了. 最简单, 你并不能确定程序运行时变量的值, 比如前一节课我们编的输入姓名的程序, 你不能确定InputBox返回的是什么(还记得Inputbox的返回值吗? 就是你输入的内容), 所以你就没有办法应对各种情况, 但我们用name这个"盒子"把用户的名字装起来, 到用的时候我们只要知道name这个盒子的名字就行了, 系统会自己打开他并把里面的内容拿出来用. 再举个例子, 我们编写一个程序计算一个矩形的面积, 比如这个程序要发给小学生使用:

    dim a,b,s
    a=15
    b=12
    s=a*b
    msgbox(s)

      这样就可以求出长为15,宽为12的矩形的面积了, 是不是很简单? 当然, 这个程序也可以这样写:

    dim s
    s=15*12
    msgbox(s)

      这样看起来程序短了许多, 也节约内存, 但并不是鼓励的做法, 为什么? 请看下面.

      现在, 我们的程序要变得像点样子才行, 谁的程序写出来还要别人修改源代码才能用啊?

      所以, 我们要接受用户的输入, 还记得吗? InputBox函数.

      修改后程序如下:

    dim a,b,s
    a=inputbox("请输入矩形的长:")
    b=inputbox("请输入矩形的宽:")
    s=a*b
    msgbox(s)

      ok, 这么一修改, 无论用户输入怎样的数据, 我们都能计算出矩形的面积了. 如果你用s=15*12能改嘛? 当然不行.

      我想你已经发现了, vbs中的数学计算和真正的算术没有什么不同, +,-,*,/,(),[],{}都是一样的用法, 比如:

    dim ans
    ans=12+32/4+[(23-10)*2]
    msgbox(ans)

      四则运算的法则在编程中同样生效, 你可以在编程中重新获得小学时候的乐趣(你恨数学?那就别学电脑了).

      在编程中有一个有趣的运算符是"mod", 这个运算符叫做"取余运算符", 就是取得一次除法的余数, 例如

    dim a
    a=16 mod 5

      你知道a等于几吗? Bingo! 没错, 就是1. 因为16 / 5 =3....1, 所以mod计算的结果就是1.

      还有一个运算符是"^"(就是键盘"6"上面的小箭头), 他表示"乘幂"(或者是"方") 比如:

    dim a,b,c
    a=2
    b=a^2
    c=a^3
    msgbox(a)
    msgbox(c)

      则b=aa=4, c=aa*a=8

      我们一次不要讲太多, 这次就讲到这里, 现在总结一下.

    要点:

    1. 常量分为自然常量和自定义常量, 常量的值不可修改

    2. 变量就像盒子, 我们不在乎盒子里装的是什么, 但一定要知道盒子的名字

    3. 四则运算在编程中没有任何不同

    4. MOD是取余运算

    作业:

    1. 编一个程序, 计算圆形的面积, 半径由用户给出 (使用Inputbox) PI取值3.14159

    2. 编一个程序取得20 / 3 的余数

    第三篇(共六篇):

    首先, 我来解决一下上次课程的几个疑问

    第一, 那个余数问题, 16 / 5 = 3...1, 是因为我改过前面的部分, 后面的忘了改了, 不好意思.

    第二, 请看一下程序清单:

    Dim a,b,c
    a=inputbox("a是:","输入半径")
    b=Inputbox("b是:","输入半径")
    c=a2+b2
    Msgbox(c)
    这个 输入1、2时是6

    Dim a,b,c
    a=inputbox("a是:","输入半径")
    b=Inputbox("b是:","输入半径")
    c=(a+b)*2
    Msgbox(c)
    这个输入1、2时是24

      为什么会不一样呢? 在数学上c=(a+b)2 和 c=a2+b2是等价的, 在VBS中也是如此. 问题出在"+"上, 在VBS中, +不仅仅是加号的意思还表示把两个字符串连接起来, 例如"Hello"+"World"="HelloWorld" have you understood? 你还记得InoutBox函数的返回值吗? 是字符串! 这就看出问题了吧, 在编程中"1"不等于(<>)1, "1"是一个字符, 而1是一个数, 所以a,b都是字符串变量, "1"+"2"="12", 这就好像我们小时跟伙伴开玩笑问他们1+1=?一样, 我们总是笑着说"错啦,应该是11".但为什么, a可以2却不发生错误呢? 这时VBS比较智能的一个表现, 如果这个字符串的内容是一个数且对他进行数学运算, 则把字符串强制转换成数参与运算, 如果字符串代表一个数, 但不参加数学运算, 而是参加字符串运算(合并)则当作字符串处理, 所以你看到a+b=12, 这时候a+b的结果(12)是一个字符串, 当它要乘以2的时候就被强制转换成了数字12, 这样我就得到了结果24.

      怎么修改这个程序呢? 我们需要用到另一个内建的函数:int, int函数的功能是将输入值转化成整数值, 我们这样修改:

    c=(int(a)+int(b))*2

      这个意思就是把a作为参数传递给int函数, int函数就会返回那个整数(你的输入值), 然后让返回值参与运算, 这样就得到了正确答案.所以,以后如果你用的是inputbox函数的话,最好用int语句加工一下:比如c=int(c) ’c是你自己的变量

      大家是不是觉得这个课程有点枯燥, 呵呵, 变量和运算符部分的确是这样的, 不过多多练习也就好了, 这次, 我们写写真正好玩的东西: 流程控制语句. 这个部分开始才是真正的编程.

      首先介绍判断结构.

      在此之前, 我们先介绍一种简单的变量类型:布尔值(Boolean), 这种变量只有两个可能值:True,Flase,即真或假. 这种变量在某些情况下很有用(比如"开关"). 我们定义一个bool变量的方法和其他变量一样, 赋值也一样, 例如:

    dim a,b
    a=true
    b=false

      注意,true和"true"是不一样的, "true"是字符串,true是布尔值, 千万不能混淆.

      回到if语句上来, 我们先来看看简化版的if语句:if 判断式 then 语句体 我们来看一个例子:

    dim a,b
    a=12
    b=13
    if b>a then msgbox("B大于A")

      我们只看最后一行, a>b这个式子(表达式)有一个返回值, 是bool型的. 因为这个式子只有两种可能:b大于a, b不大于a, 所以这个式子也只有两种可能性, 即真或者假. if语句判断这个表达式的返回值是真还是假, 如果是真(true)则执行then后面的语句, 如果是假, 则不执行, 你把a的值改成14看看还会不会弹出对话框?

      当我们要在判断之后执行多行语句怎么办呢, 我们需要用语句块来解决, 在这里可以叫块if

    dim a,b
    a=12
    b=13
    if a<b then
    msgbox("A小于B")
    msgbox("B大于A")
    end if

      两个msgbox函数夹在if和end if之间, 这个部分就是语句块, 块里的每一条语句之前请空出4--8(一个键)个格, 这不是必需的, 但是是一个好习惯, 以便看清楚程序的结构. 这样我们就能运行多于一个的语句, 请注意if...then...end if 这三个关键部分不要掉了. OK, 我出一个题, 输入一个数, 如果小于100就输出"错误", 如果大于100就输出"正确", 我这里有两个程序版本:

    dim a
    a=inputbox("请输入一个大于100的数")
    a=int(a) ’inputbox返回的是字符串, 我们把他变成整数 : )
    if a>100 then msgbox("正确")
    if a<100 then msgbox("错误")

    还有一个更简单的

    dim a
    a=inputbox("请输入一个大于100的数")
    a=int(a) ’inputbox返回的是字符串, 我们把他变成整数
    if a>100 then
    msgbox("正确")
    else
    msgbox("错误")
    end if

      看到多了一个else了吧, else的作用就是当要判断的表达式为false时执行的. 这样程序就可以处理两种不同的情况了. 不要忘了用end if结尾

      嘿嘿, 我是变态者, 现在我要你处理三种情况, <100,=100,>100, 还要写在一个if结构里, 你怎么办, 我给你答案:

    dim a
    a=inputbox("请输入一个大于100的数")
    a=int(a) ’inputbox返回的是字符串, 我们把他变成整数
    if a>100 then
    msgbox("正确")
    elseif a=100 then
    msgbox("老大, 你耍我?")
    else
    msgbox("错误")
    end if

      这次输入100看看, 是什么? else if语句可以在if结构中多次出现, 以灵活判断不同的情况 (如果你要判断得太多, 就请使用"选择结构", 过会儿就讲), 当所有elseif都处理完了,而没有符合情况的时候再执行else中的语句.另一个例子:

    Dim a,b,c,d
    a=inputbox("a是:","输入半径")
    b=Inputbox("b是:","输入半径")
    d=Inputbox("答案:","输入答案")

    c=a2+b2 ’这里没有问题, 会自动转换
    if d=c then
    Msgbox("你好聪明")
    else
    Msgbox("你好猪头 自己的题还不会!")
    end if

      再看看这个, 无论你回答得多么正确你都是猪头, 哈哈, 不是我耍你, 还是文章开始时候的inputbox的返回类型在耍你, d是inputbox的返回值, 他是一个字符串, 而c是一次整数计算的结果, 他是一个整数. 一个字符串无论如何也不等于一个整数, 尽管他们字面上是一样的:"8"<>(不等于号)8 所以if的判断式的值永远是false, 总是执行else部分的语句. 我们可以这么修改

    Dim a,b,c,d
    a=inputbox("a是:","输入半径")
    b=Inputbox("b是:","输入半径")
    d=Inputbox("答案:","输入答案")
    d=int(d)
    ’在这里我们取出了d的值, 变成整数, 在放回"d"这个盒子里
    c=a2+b2
    if d=c then
    Msgbox("你好聪明")
    else
    Msgbox("你好猪头 自己的题还不会!")
    end if

      这样就成功了. 这也是Inputbox函数的一个讨厌的地方, 没办法, vbs没有其他好的输入方式了.

      说到if, 我们不得不说一说逻辑运算符, 今天介绍两种, "and" 和 "or" 学会了if语句之后, 我举一个例子, 你一看就明白了.

    dim a,b
    a=inputbox("输入一个数 >10")
    b=inputbox("输入另一个数 >10")
    a=int(a)
    b=int(b)
    if a>10 and b>10 then
    msgbox("正确")
    else
    msgbox("错误")
    end if

      这段程序让你输入两个值, 必须都大于10, 只要有一个不大于, 就输出错误

    dim a,b
    a=inputbox("输入一个数 >10")
    b=inputbox("输入另一个数 >10")
    a=int(a)
    b=int(b)
    if a>10 or b>10 then
    msgbox("正确")
    else
    msgbox("错误")
    end if

      这段程序让你输入两个值, 只要有一个大于10, 就返回成功. 其实and和or很好理解, 我读"if a>10 or b>10 then" 这一句, 用华语是这样:"如果a大于10或者b大于10, 那么...". 这样是不是就很好理解了呢.

      OK, 我们再来看一种新结构, 今天的课就结束, 已经午夜了, 我都累死了.

      当你的程序要处理很多种不同的判断情况的时候elseif..then会让程序看起来很杂乱, 所以就有了一种select case结构专门对付这种情况, select case的语法结构很简单:

    select case 变量名 
    case 值 
     语句 
    case 值 
        语句 
    case else 
        语句 
    end select 
    

      我们举个例子就能很简单的说明:

    dim a
    a=inputbox("输入一个1--3的值")
    a=int(a) ’处理inputbox返回字符串的问题
    select case a
    case 1
    msgbox("壹")
    case 2
    msgbox("贰")
    case 3
    msgbox("叁")
    case else
    msgbox("输入错误")
    end select

      这个例子把1,2,3这三个阿拉伯数字转化成中国大写数字, 这个程序写成if...elseif 的形式如下

    dim a
    a=inputbox("请输入1--3的值")
    a=int(a)
    if a=1 then
    msgbox("壹")
    elseif a=2 then
    msgbox("贰")
    elseif a=3 then
    msgbox("叁")
    else
    msgbox("输入错误")
    end if

      怎么样, 麻烦吧, 还是select好吧.

      OK, 今天到此结束, 总结一下:

    要点:

    1. inputbox返回的是一个字符串, 而不是一个数, 必须用a=int(a)这种形式转化成数

    2. bool变量的值只有两种:true,false

    2.5) and两边的表达式都是true, 则返回true. or两边的表达式有一个是true, 就返回true

    1. if 语句的格式

    2. select...case的格式

    作业:

    1. 使用3个bool值, 储存你的3兄弟姐妹是否是男性 (提示:sister1male=false)

    2. 给定一个个数, 大于10而且小于20输出"正确", 否则输出"错误"

    3. 输入12,或者15, 输出"正确", 否则输出"错误"

    4. 把5以内的正整数都转换成中国大些数字

    5. 自己随便设计一个程序, 应用今天的知识


    eniac,2005-04-04 15:47:55

    四篇(共六篇):

    大家好, 昨天我休息了一天, 所以今天写第4章:循环结构

      我们先来看一道题:商场进行每日结算, 要求累加出今天的营业额, 每次输入一个数, 这道题其实很简单, 但就我们现在学

    过的知识要完成这道题相当麻烦, 我们来分析一下. 首先, 我们需要知道买卖的次数, 这样才能控制输入的次数,但是, 这种设

    计是非常低效的, 每天都要重新设计程序. 假定今天进行了5次交易, 以下是源程序:

    dim sum
    sum=0 ’初始化变量
    sum=sum + int(inputbox("请输入交易额"))
    ’sum=sum+x 这种形式是把本身的值取出来, 进行一次运算, 再放回本身, 这种方法很有用处
    ’这里使用了函数嵌套, 把inputbox的返回值直接传给int函数, 转化成整数, 下同
    sum=sum + int(inputbox("请输入交易额"))
    sum=sum + int(inputbox("请输入交易额"))
    sum=sum + int(inputbox("请输入交易额"))
    sum=sum + int(inputbox("请输入交易额"))
    msgbox(sum)

      看到了吗, 我通过把计算过程复制了5遍才设计好了程序, 这种程序在汽车交易所等交易次数少的地方还能凑合着用, 如果

    放到超市岂不是要复制, 粘贴几千遍? 我们今天讲的内容就可以克服这种缺陷, 首先, 我们来讲以下Do...Loop语句.

      do...loop的结构看上去非常简单, 就是:do...loop, 仅此而已, 这个结构不断执行do和loop之间的语句(学名叫:循环体),
    永不停止. 举个例子来说:

    do
    msgbox("这个信息会不断重复出现, 要停止程序请使用任务管理器(Ctrl+Alt+Del)中止wscript进程")
    loop

      运行这个程序, 当你点销掉一个对话框马上会出来另一个, 你永远点不完, 总有下一个. 谁会运行这样的程序? 除非是给

    别人捣乱(我就干过这种事), 所以在do..loop结构中还有一个语句:exit do, 这个语句将终止循环, 跳到loop后面的语句继续

    执行. 据个例子来说:

    dim a ’注意:常量不需要在dim里面声明,否则会引发错误
    const pass="123456" ’这是一个字符串 请用""包裹起来. 设定密码为常量, 不可变更
    do
    a=inputbox("请输入密码")
    if a=pass then
    msgbox("密码校验成功")
    exit do
    end if
    loop

      这个程序会一直不停的问你密码, 知道你输入了正确的密码为止.(if可以嵌套在另一个if当中, 也可以嵌套在循环体当中

    , 所以一定要用缩进, 来分清楚程序的各个部分). 这个程序是很经典的, 早期的程序都是这么做的. 但是我们是Hacker, 所以

    我们了解系统的安全性, 这种无限次认证程序很容易被穷举破解, 我们要来限定认证的次数. 修改程序如下

    dim a,ctr
    ctr=0 ’设置计数器
    const pass="pas123_" ’上面的那个是弱密码, 这次改的强一点
    do
    if ctr=3 then
    msgbox("已经达到认证上限, 认证程序关闭")
    exit do
    else
    a=inputbox("请输入密码")
    if a=pass then
    msgbox("认证成功")
    msgbox("(你可以在这里加一段成功后得到的信息)")
    exit do
    else
    ctr=ctr+1 ’如果密码出错就增加一次错误认证计数
    msgbox("认证出错, 请检查密码")
    end if
    end if
    loop

      运行这个程序试试看, 当你出了3此错误以后, 就会停止再次询问密码, 关闭程序. telnet认证用来限制次数的程序与此大

    同小异. 要注意的是嵌套的if语句, 清仔细读一下这个程序, 可能比较难懂, 也请你试着自己设计一下类似的程序.

      其实, 要在do...loop加上验证的功能, 并不一定要用if, 我们可以直接利用do. 我来介绍一下while关键字, while可以放
    在do或者是loop后面, 然后再接一个表达式, 当表达式的值为true的时候(表达式成立),才运行循环体.我们来看一下修改后的
    程序"

    dim a,ctr
    ctr=0
    const pass="pas123_"
    do while ctr<3
    a=inputbox("请输入密码")
    if a=pass then
    msgbox("认证成功")
    msgbox("(你可以在这里加一段成功后得到的信息)")
    exit do
    else
    ctr=ctr+1 ’如果密码出错就增加一次错误认证计数
    msgbox("认证出错, 请检查密码")
    end if
    loop

      这样实现的功能和上一个例子完全一样, 我们再来看看把while放在loop后面:

    dim a,ctr
    ctr=0
    const pass="pas123_"
    do
    a=inputbox("请输入密码")
    if a=pass then
    msgbox("认证成功")
    msgbox("(你可以在这里加一段成功后得到的信息)")
    exit do
    else
    ctr=ctr+1 ’如果密码出错就增加一次错误认证计数
    msgbox("认证出错, 请检查密码")
    end if
    loop while ctr<3

      功能是一样的, 为什么要放在loop后面呢? 你把ctr的值改成3就知道了, while在do后面的程序会直接退出, 而在loop后面

    还会允许一次认证, 到了loop才结束.和while相反的是until, 用法和while一样, 不过他只有当后面的表达式的值为false(表

    达式不成立)的时候才执行循环体, 请自己试验一下

      ok, 我们来看另外一种循环结构,for....next, 这种循环结构是基于计数的, 也是在编程中最常见到的循环结构.

    dim i
    for i=0 to 5
    msgbox(i)
    next

      看到了吗?每次输出的i都是递增的, 但我们没有明确指出i要递增, 当i达到5的时候, 循环就结束了, 因为由0开始, 所以

    循环体执行了6次, 这一点很重要, 大部分东西都是从0开始而不是1. 这个程序也可以写成

    do的形式:

    dim i
    i=0
    do while i<5
    msgbox(i)
    i=i+1 ’因为do不能自动计数, 必须手动加
    loop

      怎么样, 还是for比较好用吧. for在编程中很有用途, 我们再举一个例子, 顺便讲一下嵌套循环.

    dim i,j
    for i=1 to 9
    for i=1 to 9
    str=str & i * j & " " ’&是和并字符串的符号
    next ’每个next对应一个for
    next

      看看运行结果, 是否令你会想起小学时代的数学老师(丑陋的嘴脸). 要注意, 这里有一个"大"的for, 和一个小的for, 当

    小的for执行完一个周期以后, 大的for才执行一次(换句话说, 大的for执行一次, 小的要执行9次), 所以一共执行了九九八十

    一次. 在大的for里可以不仅仅是一个小的for, 也可以加上另外的语句. 我们来修改一下源程序:

    dim i,j
    for i=1 to 9
    for i=1 to 9
    str=str & i * j & " "
    next ’每个next对应一个for
    str=str & vbCrlf ’vbCrlf相当于键盘上的回车键,因为你不能在键盘上输入,所以系统定义了一个默认的常量
    next

      这次运行完成以后, 输出结果按照乘数进行了分割, 每小for运行完一次, 就换一行(通过vbcrlf).

      这次的内容对菜鸟可能比较难懂, 掌握的办法只有一个:多实践. 另外, 我在论坛看到很多人还是问:"VBScript要用什么工

    具编?"我就很气愤, 我在第一篇里面已经说明:用记事本编辑源代码, 然后保存为以.vbs为扩展名的程序就可以了, 请大家不要

    再问. 另外, 国产的一种垃圾软件"超级X霸"抢占了vbs这个扩展名, 请把那个垃圾卸载掉.

      我们总结一下:

    要点:

    1. do..loop和exit do的用法

    2. while当表达式true的时候执行循环体,until反之

    3. for...next是计数循环, 每次执行计数器递加

    4. 嵌套循环的作用和写法

    4.5) &用于连接字符串

    1. vbCrLf相当于键盘上的回车键

    作业:

    1. 在我国的数学经典著作"九章算术"中有这样一道题:百钱买百鸡, 公鸡5钱一只, 母鸡3钱一只, 小鸡1钱2只(这个数据我是参

    考一本编程书的, 但我记得是公3,母1,小1钱3只? 不管了, 就按照书上得来吧)求得是能有多少种办法买这些鸡. 如果看不懂的

    话我用大白话说说:有人要去买鸡, 用100块钱正好买了100只鸡, 价格如下:公:5$, 母:3$, 小:1$ for 2, 让你求一共多少种卖

    法(公母小怎么搭配). 请用循环解决这个问题.

    ps:今天要去移民局办事, 所以文章写的很仓促. 大部分代码都没有实验, 请大家帮我找错. 另外, 上次的作业大家在论坛应该

    看到了, 我就不重复答案了, 不知道大家喜欢做这种题, 还是以前那种比较简单的?

    第五篇(共六篇):

       请允许我县描述一下我现在的环境:气温高达37摄氏度, 而我忘记了图书馆开门的时间, 还要在这里站上一个小时, 在热带植物的包裹下, 各种奇怪的小飞虫围着我转来转去. 不过令我欣慰的是, 终于写到五了, 还有两课我们的"基础篇"就要结束了. 
    
       今天我们来了解语言本身的最后一个论题:数组. 
    

      要理解"数组", 这个概念我觉得另一种翻译对学习来说更加容易:"阵列", 没错, 数组就是一个阵列, 一个数据的阵列. 最简单的例子是数据库系统, 假设你要储存20名学生的英语成绩, 如果不是用数组, 你则要创建20个不同的变量, 累死. 数组就是类型相同(重要!)的一组数据(或者n组), 用来储存相关的量, 最简单的数组是一维数组, 我们就先来学习它吧.

      什么是一维数组呢? 在3维以下,你可以利用几何知识来理解"维"的概念,一维相当于一条线, 二维则是一个矩形, 三维是一个长方体. 我知道这么讲是很抽象的, 我们先举个一维数组的例子就比较容易了解了.

    dim a(9) ’从零开始
    for i=0 to 9
    a(i)=i ’填充每一个数组元素
    msgbox(a(i)) ’输出数组元素
    next

      我们可以看到, 定义一个数组的方法和定义一个变量没有什么不同, 同样是使用dim语句. 定义一维数组的方法如下:

    dim 数组名(元素数量), 这里大家要注意一点, 这里定义的元素数量总是比你要的要少一个, 因为一个数组的起点是0号数据而不是1, 所以大家一定要小心: 你需要10个数据, 就定义"9", 需要100个就定义99, 依此类推. 数组的元素可以看成一个个独立的变量, 你可以像独立的变量那样使用他们. 数组元素的量可能是毫无关系的, 比如第一个数组元素储存你的年龄, 第二个储存今年西瓜的销售量, 但这种做法是不鼓励的, 甚至是不被接受的, 不要这么干, 这样的情况请定义独立的变量. for语句在数组中可算是大显身手, 还记得for吗? 它累加一个变量, 我们可以把这个变量应用在数组中正好用来读取或者填充按照顺序排列的数组元素, 上面就是这样一个例子. 数组其实是很简单的东西(再BASIC语言里面), 数组难的是怎么捣弄这些循环, 让他们按照你的要求运转. 这个等到二维数组再说, 我们先看看如何手工填充数组.

      如果你这个都想不到的话, 那你真是白学了:

    dim name(7),str ’一共八个学生, str变量是用来把他们储存成一个字符串以便输出
    for i=0 to 7
    name(i)=inputbox("请输入第" & i+1 & "个学生的名字")
    str=str & " " & name(i)
    next
    msgbox(str)

      这样我们就有了一个小小的数据库, 它们的数据排列可以看成这样:

      name(0),name(1),name(2).....name(7)

      看到了吧, 所以我说我们可以把它看成是"一条线", 等到我们学到了文件操作, 就可以把他们输出到文件中去了. 一维数组有很多用处, 我们来看一下一个复杂的例子. 我们要储存3各学生的名字, 身高, 成绩这三种数据, 由于名字是字符串, 而身高可能是浮点数(带小数点的数), 成绩则可能是整数, 所以我们不能把他们储存在一个数组里面(不要忘记, 数组织只能存储同类的数据), 所以我们要建3个数组, 以下是例程:

    dim name(2), high(2), mark(2) ’定义三个数组分别储存3个人的名字, 身高和得分
    dim ctr ’计数器
    for ctr=0 to 2
    name(ctr)=inputbox("请输入第" & ctr+1 & "个学生的姓名")
    high(ctr)=inputbox("请输入第" & ctr+1 & "个学生的身高")
    mark(ctr)=inputbox("请输入第" & ctr+1 & "个学生的得分")
    next

      OK, 我们已经填充好了数据, 现在我们的小小数据库只能按顺序输入, 我们要让它看起来像点样子, 我们来给他设计查询功能:

    ’接着上面的程序
    dim cname, temp ’要查询的名字, 和一个临时变量, 用来储存数据的位置
    cname=inputbox("请输入你要查询的名字:")
    for ctr=0 to 2 ’遍历所有name数组的成员, 寻找要查询的名字
    if name(ctr)=cname then
    temp=ctr ’记录数据位置
    exit for ’退出循环, 和exit do的用法一样
    end if ’不要忘了end if
    next
    msgbox("姓名:" & name(temp) & " " & "身高:" & high(temp) & " " & "得分:" & mark(temp))

      嘿嘿, 有意思吧, 其实在这个程序里面, 那个temp变量完全没有必要, 只是为了更清楚地说明问题. 因为当exit for以后ctr变量的值就不会改变, 储存的正好是对应数据在数组中的位置, 写这个temp变量是为了照顾到以后要学C++的朋友(C++可以在for语句里声明新变量, 只在这个for结构中有效, 所以到了外部就不能访问了). 也就是说可以简化成如下:

    dim cname
    cname=inputbox("请输入你要查询的名字:")
    for ctr=0 to 2
    if name(ctr)=cname then exit for ’因为只有exit for就不需要块if了
    next
    msgbox("姓名:" & name(ctr) & " " & "身高:" & high(ctr) & " " & "得分:" & mark(ctr))

      这是最直接的路子. 好好重读一下上面所有的源代码, 然后自己写几个程序, 完全搞清楚一维数组及其应用以后再看后面的二位数组. 二维数组好像是一个一维数组的集合, 就好像"线积成面"一样, 由n各一维数组组成二维数组, 这是初学者比较好理解的办法(比较精确的是用"编号"的概念去理解, 因为4维以上的数组就比较难以用欧几里德几何概念去解释了). 二维数组是很好解释的, 我们来看一下:

    dim a(2,2) ’从零开始, 一共有3 X 3 = 9 个数据
    dim i,j ’需要两个计数器
    for i=0 to 2
    for j=0 to 2 ’使用嵌套循环
    a(i,j)="X"
    next
    next

      我们创建了一个这样的二维数组(那些","是我用来分割元素的,并不存在), 了解二维数组的了吗? 不清楚我们再讲一下

    编号 0 1 2
    0 X,X,X
    1 X,X,X
    2 X,X,X

      二维数组的看起来是不是就是一个矩形呢?(你在内存中看不到这样的矩形, 只是便于你理解), 每个数据都有编号, 由两个数来定位, 这个很像(非常像)你在国际象棋棋盘上寻找一个格, 我们用类似"C6","A2"这样的"垂直坐标"进行定位, 对, "垂直坐标", 很确切. 我们要使用一个二维数组元素的时候可以和普通变量一样使用, 只要指定数组元素的"定位点"就可以了, 例如

    a(0)(1)=1, b(2)(1)="你好", 诸如此类. 要注意的是二维数组也只能储存类型相同的元素, 而且上标(起点)也从0开始. 计算一个二维数组的元素个数只要把两个下标+1(以得到实际的值)再乘起来就可以了, 非常类似于求一个矩形的面积.

      假如需要储存的都是同一类型的数据, 我们就可以用二维数组, 比如要储存5个人的姓名,国籍,民族, 就可以使用二维数据

    dim info(4,2) ’一共五个人, 要储存的数据类型有3项
    dim i,j
    for i=0 to 4
    for j=0 to 2
    dim opt ’定义一个变量用于存储数据项提示
    select case j ’判断应该输入的是什么数据
    case 0
    opt="姓名"
    case 1
    opt="国籍"
    case 2
    opt="民族"
    end select
    info(i,j)=inputbox("请输入第" & i+1 & "个人的" & opt)
    next
    next
    ’输出太麻烦了, 我懒得动, 你知道那么回事就行了

      这样就不需要定义3个一维数组了.

      多位数组(三维以上)的定义和使用方法与二维数组一样, 但不太好在欧几里德几何空间里加以解释, 幸好我们并不太常用那么多维的数组.定义一个三位数组:dim a(1,2,3) ’一共24各数组元素.

      今天因为要搬家(我喜欢Sengkang啊, 可是MM嫌交通不便, 谁不知道她只想去逛街),而GF要去和她的同学去参加什么试验半夜才回家, 所以下午我只能自己去押车搬家了, 5555~~好可怜, 这次就请大家原谅我少写一点, 我可是站在图书馆外写的啊,

    现在腿都软了~~~ 本来还要讲"动态数组"的, 但想了想还是放到"进阶部分"再说吧.

    要点:

    1. 一维数组是"线", 二维数组是"面", 三维数组是"体" (多维数组就乱套)

    2. 数组的下标从0开始

    3. for循环在数组的应用中起了很大作用, 二维数组需要嵌套循环

    作业:

      上次出的"百鸡问题", 大家喜欢吗? 以后我们就做这种需要动脑的题目, 那些简单的实践, 大家一定要多做!

    1. 定义一个数组, 包含5个元素, 都是随机整数(随便输入), 要求把他们按照从大到小的顺序排列起来

    2. 有两个二维数组a(4,4)和b(4,4) (元素值随便), 交换两个数组(原来的a的所有元素值变成b的, b的所有元素值变成a的)

    最后一篇:

    新家不错, MM开心, 我也就跟着高兴了 : ), 今天我们学习基础篇的最后一个部分:自定义函数和过程. 我们每天都在和函

    数打交道, inputbox()是函数, msgbox()是函数, int()也是函数...这些函数都是系统内建的, 我们只能用不能改. 今天, 我

    就教大家怎样自己制作一个函数.

      首先我们要了解, 为什么要用函数, 我们用"实例"说话, 先看一个例子: 给出两个数, 输出较大的那一个.

    dim a1,a2,b1,b2,c1,c2
    a1=2:a2=4 ’":"可以让你把多个语句写在一行上
    b1=32:b2=67
    c1=12:c2=898

    if a1>a2 then
    msgbox(a1)
    elseif a1<a2 then
    msgbox(a2)
    end if

    if b1>b2 then
    msgbox(b1)
    elseif b1<b2 then
    msgbox(b2)
    end if

    if c1>c2 then
    msgbox(c1)
    elseif c1<c2 then
    msgbox(c2)
    end if

      多么麻烦呀, 我们把相同的比较过程复制了好几遍, 早期语言没有结构化(没有过程和函数)的时候, 程序员们的确是这么

    干的, 他们复制(Copy), 那个年代也没有剪贴板这一说, 大家都是重新输入代码. 后来工作简化了:

    dim a1,a2,b1,b2,c1,c2
    a1=2:a2=4
    b1=32:b2=67
    c1=12:c2=898
    msgbox(co(a1,a2))
    msgbox(co(b1,b2))
    msgbox(co(c1,c2))

    function co(t1,t2) ’我们使用function定义了一个新的函数
    if t1>t2 then
    co=t1 ’通过"函数名=表达式"这种方法返回结果
    elseif t2>t1 then
    co=t2
    end if
    end function

      我们在这里是用了一个新的关键字:funciton, 这个关键字表示一个新函数开始, 格式:

    funciton 函数名(参数1, 参数2...参数n) ’列表可以是空的, 但括号不能省略, 参数之间用","分割 
    ... 
    exit funciton ’结束函数, 不是必需的 
    ... 
    end function 
    

      函数是一个模块, 只有你调用的时候才会运行, 也就说, 当你编写了一个函数, 然后在程序中并不调用它, 那么这个函数

    永远不会运行. 一般来说, 我们编写程序是按照:

    主程序
    ..
    ..
    ..

    函数1
    ..
    ..

    函数2
    ..
    ..

      详细解释一下: 函数中最重要的是参数和返回值. 参数是在函数名后面的()里定义的, 用","分割, 使用参数的时候我们也

    用","分割. 说到这里我想起一件事, 昨天有个朋友给我发消息问我:

      msgbox(name1,name2,name3)

      这个错在哪里? 为什么不能同时显示出三个变量? 这就是因为你用了",", 这个符号表示你输入的三个量作为三个不同参数

    传递给msgbox()函数, msgbox()函数只会显示出第一个参数, 第二个参数的作用是出现在标题栏. 所以你应该用"&"或者"+"把

    三个字符串变量连接起来, 作为第一个参数传递给msgbox()函数. 程序员说参数的时候经常说到"形参", "实参"这样的"黑话",

    我来解释一下. "形参"是"形式参数"的简称, "实参"是"实际参数"的简称, 实参是指你调用函数的时候传递给函数的量, 可以

    使变量或者常量(直接量), 例如:co(12,24)中的12,24就是实参. 形参是你在函数定义时定义的变量, 这些变量用来"接住"传递

    过来的量, 例如function co(t1,t2)t1,t2就是形参.

      在VBScript中, 参数传递是一种传值, 而不是传址(听不明白不要紧, 学了C语言的指针你就明白了), 所以我们进行的参

    数传递实际上是进行了一次变量赋值, 例如我们调用co(a1,a2), 实际上程序会执行一步:t1=a1,t2=a2这样的操作. 同样因为传

    值传址的原因, VBScript只能返回一个值, 我们先来看看什么叫"返回". 当一个过程调用了另一个过程的时候(比如主程序调用

    了函数), 控制权就到了被调用过程那里, 当这个过程执行完毕以后, 会回到调用它的地方继续执行, 这个就叫做"返回", 返回

    的时候可以带一个值叫做"返回值"(这是"通俗"的理解). 在vbs继承了basic的传统, 返回的时候采用"函数名=返回值"的办法,

    这个"返回值"是指一个表达式(在编程中, 任何东西都是表达式, 比如变量a, 常数0, "Hello",c=1+2等等这都是表达式). 比如

    有一个函数是ht, 则返回的方法是:ht=你要返回的值. 注意:返回以后, 后面的语句将不再执行.

      调用一个函数我就不用讲了吧:变量=函数名(参数)

      有时候我们并不需要返回什么值, 这个时候我们可以使用一种称之为"子程序"的结构. 子程序或称之为过程与函数的差别

    就在于:1) 没有返回值, 2) 使用sub关键字定义, 3) 通过Call调用.具个例子:

    dim yname
    name=inputbox("请输入你的名字:")
    call who(yname)

    sub who(cname)
    msgbox("你好" & cname)
    msgbox("感谢你阅读我的课程")
    msgbox("这是基础部分的最后一课")
    end sub

      你一定看明白了, 很简单的. 退出一个过程和退出一个函数一样:exit sub(函数:exit function).

      要注意, 子程序(过程)是比较特殊的一个结构, C等语言是没有这个概念的, C语言中的一切都是函数, 没有返回值的函数

    在C语言中只要使用void修饰符定义就行了.

      今天没有什么可讲的了, 基础篇就这么结束了, 目前你已经有了基本的编程概念(面向过程的结构化编程), 可以选择学习

    另外一种语言(比如C或Pascal), 现在的基础会有一定的帮助. 如果你想要继续学习vbs或通过它更详细的了解编程在转型可以

    跟我继续学习, 但因为我的假期结束所以更新的时间可能会比较慢, 请大家原谅.初步计划如下:

    进阶篇:

    变量的深入讨论
    |
    |----变量类型
    |
    |----变量的有效范围
    |
    数组的深入讨论
    |
    |----动态数组
    |
    函数的深入讨论
    |
    |----数组作为函数参数
    |
    |----多个返回值
    |
    字符串操作
    |
    |----乱七八糟一大堆
    |
    面向对象编程(OOP)的基本知识
    |
    文件操作
    |
    |----FSO对象
    |
    |----其他相关部分
    |
    VBS与网页
    |
    |----HTML中嵌入VBS
    |
    |----VBS与表单(设计你的程序界面 wow!)

    实战篇:

    病毒编程

    Socket编程(TCP/UDP)

      这只是大概的内容, 我想应该会有变化, 到时候你就会读到的. 今天的内容请多多实践, 作业就是把前面的各个课程在温

    习一下. 对要离开这个课程去更进一步学习的朋友:祝你再学习编程的道路上一帆风顺.


    eniac,2005-04-04 15:49:21

    引用:http://twct.com/blogview.asp?logID=59&cateID=9

    二级域名原理以及程序,申请即可开通

    要达到二级名的效果,必须一下条件以及流程:
    1、必须有一个顶级域名,而且此域名必须做好泛解析并做好指向。
    2、必须有一台独立的服务器。泛解析的域名指向该服务器。
    3、在服务器上的IIS建一个空的主机头名的web站点。
    4、将默认的页面设置为你的二机解析程序(比如:freedns.asp)
    5、二级域名系列程序(包括申请页:shenqing.htm,添加页add.asp,解析页,)

    此程序的优点:
    a,可以限制申请域名的敏感字,比如 hacker,wwww,sex,china等
    b, 可以限制申请域名的非法字,比如:!·#¥%……—()——?‘“/等
    c, 每个地址只能申请一个域名。
    d,限制申请域名的长度,
    e, 如果用户所访问的域名没人申请则转到特定的页面,本例中的http://www.51bxg.com/miss.html
    f, 申请了域名:
    .yourname.com 可以同时支持:http://.yourname.com 以及http://www.**.youranme.com 两个域名的访问。

    一下为系列程序代码:
    shenqing.htm


    加*号为必填内容
    您想注册的域名: http:// .51bxg.com     
    你实际的网站地址: 你要求显示的title:
      

    添加记录页面add.asp

    <%
    uID=request.cookies("*****")
    %>
    <%
    dim nowurl,tourl,company,along,pbkey
    nowurl=trim(request.form("nowurl"))+".51bxg.com"
    nurl=trim(request.form("nowurl"))
    tourl=trim(request.form("tourl"))
    company=trim(request.form("company"))
    along=20
    pbkey="www,sex,admin,w,ww,wwww,hacker,hack"

    set rs=server.createobject("adodb.recordset")
    sql="select * from dns where userid='"&uid&"'"
    rs.open sql,conn,1,1
    if not rs.EOF then
    response.write"很抱歉,你已经申请过二级域名,每个用户只能申请一个二级域名!
    你申请的二级域名是:http://"+rs("nowurl")
    response.end
    end if

    set rs=server.createobject("adodb.recordset")
    sql="select * from dns where nowurl='"&nowurl&"'"
    rs.open sql,conn,1,1
    if not rs.eof then
    response.write"很抱歉,你申请的域名:http://"+nowurl+"已经被其他公司申请,请另外申请域名。"
    response.end
    end if

    if len(nurl)>along then
    response.write"很抱歉,你输入的域名太长,请重新输入"
    response.end
    end if

    if instr(pbkey,nurl) then
    response.write"很抱歉,你输入的域名因为含有敏感字而不管理员屏蔽,请重新输入。"


    response.end
    end if

    '判断字符的合法性
    if instr(nurl,"~") or instr(nurl,"") or instr(nurl,"/") or instr(nurl,"?") or instr(nurl,">") or instr(nurl,"<") or instr(nurl,";") or instr(nurl,":") or instr(nurl,"}") or instr(nurl,"{") or instr(nurl,")") or instr(nurl,"(") or instr(nurl,"*") or instr(nurl,"&") or instr(nurl,"^") or instr(nurl,"%") or instr(nurl,".") or instr(nurl,",") or instr(nurl,"'") or instr(nurl,"~") or instr(nurl,"!") or instr(nurl,"$") then response.write"很抱歉,你输入的域名含有非法字符,请重新输入,以下字符为非法字符:<br>~ / ? > < ; : } { ) ( * & ^ % $ # @ ! "
    response.end
    end if

    set rs=server.createobject("adodb.recordset")
    sql="select * from ** where theid is null"
    rs.open sql,conn,3,3
    rs.addnew
    rs("userid")=uID
    rs("nowurl")=nowurl
    rs("tourl")=tourl
    rs("company")=company
    rs.update
    response.write"祝贺,申请成功,你马上就可使用你的域名:http://"+nowurl
    %>

    域名解吸程序: freedns.asp

    <%
    dim geturl
    geturl=replace(Request.ServerVariables("HTTP_HOST"),"www.","")

    set rs=server.createobject("adodb.recordset")
    sql="select * from tb where nowurl='"&geturl&"'"
    rs.open sql,conn,1,1
    if rs.eof then
    response.redirect"http://www.51bxg.com/miss.html"
    else
    dim tourl,company
    tourl=rs("tourl")
    company=rs("company")
    %>

    <% =company %> <body> <p>This page uses frames, but your browser doesn't support them.</p></body> <% end if %>

    eniac,2005-04-04 15:49:55

    引用:http://twct.com/blogview.asp?logID=119

    FSO对象模型的应用 [ 2005-3-14 | Young's BLOG ]
    二、FSO对象模型的应用
    (一)创建FSO对象模型
    由于FSO对象包含在Scripting 类型库 (Scrrun.Dll)中,所以在使用前首先需要在在工程中引用这个文件,单击“工程”,“引用”,然后在“引用”对话框中选中“Microsoft Scripting Runtime”前的复选框,然后单击“确定”。
    要创建FSO对象可以采用两种方法,一种是将一个变量声明为FSO对象类型:Dim fsoTest As New FileSystemObject;另一种是通过CreateObject方法创建一个FSO 对象:Set fsoTest = CreateObject(“Scripting.FileSystemObject")。在实际使用中具体采用哪种声明方法,可根据个人的使用习惯而定。
    完成了FSO对象模型的创建之后,就可以利用创建的对象模型的方法访问下属各个对象的属性来获取所需信息或进行相关操作了,具体的方法在下面结合各个对象分别讲述。
    (二)Drive对象
    上面已经提到Drive对象是用来获取当前系统中各个驱动器的信息的。由于Drive对象没有方法,其应用都是通过属性表现出来的,所以我们必须熟悉Drive对象的属性:
    AvailableSpace:返回在指定的驱动器或网络共享上的用户可用的空间容量。
    DriveLetter :返回某个指定本地驱动器或网络驱动器的字母,这个属性是只读的。
    DriveType:返回指定驱动器的磁盘类型。
    FileSystem: 返回指定驱动器使用的文件系统类型。
    FreeSpace:返回指定驱动器上或共享驱动器可用的磁盘空间,这个属性是只读的。
    IsReady:确定指定的驱动器是否准备好。
    Path :返回指定文件、文件夹、或驱动器的路径。
    RootFolder :返回一个 Folder 对象,该对象表示一个指定驱动器的根文件夹。只读属性。
    SerialNumber:返回用于唯一标识磁盘卷标的十进制序列号。
    ShareName:返回指定驱动器的网络共享名
    TotalSize :以字节为单位,返回驱动器或网络共享的总空间大小。
    VolumeName :设置或返回指定驱动器的卷标名。
    从上面的属性可以看到Drive对象基本上包含了日常操作所需的全部的驱动器信息,因此在使用中是非常方便的。下面通过一个实例讲述Drive对象的使用。首先在VB中建立一个工程,然后添加一个命令按钮,将其Caption设置为“TestDrive”,然后在click事件中加入以下代码:
    Dim fsoTest As New FileSystemObject
    Dim drv1 As Drive, sReturn As String
    Set drv1 = fsoTest.GetDrive(“C:")
    sReturn = “Drive " & “C:" & vbCrLf
    sReturn = sReturn & “VolumeName" & drv1.VolumeName & vbCrLf
    sReturn = sReturn & “Total Space: " & FormatNumber(drv1.TotalSize / 1024, 0)
    sReturn = sReturn & “Kb" & vbCrLf
    sReturn = sReturn & “Free Space: " & FormatNumber(drv1.FreeSpace / 1024, 0)
    sReturn = sReturn &“Kb" & vbCrLf
    sReturn = sReturn &“FileSystem:" & drv1.FileSystem & vbCrLf
    MsgBox sReturn
    其中GetDrive方法返回一个与指定路径中的驱动器相对应的 Drive 对象。该方法的语法格式为object.GetDrive drivespec,object是一个FSO对象的名称,drivespec用于指定驱动器的名称。
    按F5运行上述代码,按下TestDrive按钮就会弹出一个消息框显示C盘的信息。
    (三)Folder对象
    在FSO 对象模型中,提供了丰富的有关文件夹操作的方法,这些方法分别是:
    FileSystemObject对象有关文件夹的方法:
    CreateFolder :创建一个文件夹 。
    DeleteFolder:删除一个文件夹 。
    MoveFolder :移动一个文件夹 。
    CopyFolder:复制一个文件夹 。
    FolderExists: 查找一个文件夹是否在驱动器上 。
    GetFolder :获得已有Folder对象的一个实例 。
    GetParentFolderName: 找出一个文件夹的父文件夹的名称。
    GetSpecialFolder: 找出系统文件夹的路径。
    Folder对象的方法:
    Delete :创建一个文件夹 。
    Move :移动一个文件夹 。
    Copy:复制一个文件夹。
    Name:检索文件夹的名称。
    在此需要强调一点,前面我们曾经提到过FSO对象模型包含的方法是冗余的,所以Folder对象的Delete、Move、Copy方法和FileSystemObject对象的DeleteFolder、MoveFolder、CopyFolder方法实际上是相同的,因此在实际使用中可以任选其中的一种。
    和Drive对象一样,下面通过实例演示Folder对象的应用。在VB下新建一个工程,然后在上面添加三个命令按钮,然后在Form1的通用部分加入以下代码:
    Option Explicit
    Dim fsoTest As New FileSystemObject
    Dim folder1 As Folder
    并且分别在三个命令按钮的click事件输入以下代码:
    Private Sub CmdCreate_Click()
    ' 获取 Folder 对象。
    Set folder1 = fsoTest.GetFolder(“C:")
    '创建文件夹
    fsoTest.CreateFolder (“C:\Test")
    MsgBox “folder C:\Test has created"
    End Sub
    Private Sub CmdDelete_Click()
    ' 获取 Drive 对象。
    Set folder1 = fsoTest.GetFolder(“C:")
    '删除文件夹
    fsoTest.DeleteFolder (“C:\Test")
    MsgBox“folder C:\Test has deleted"
    End Sub
    Private Sub CmdGetPro_Click()
    '获取文件夹的有关信息
    Dim sReturn As String
    Set folder1 = fsoTest.GetFolder(“C:\Windows")
    'sReturn = “The folder's Attributes is " & folder1.Attributes & vbCrLf
    '获取最近一次访问的时间
    sReturn = sReturn & “The folder's last access time is " & folder1.DateLastAccessed & vbCrLf
    '获取最后一次修改的时间
    sReturn = sReturn & “The folder's last modify time is " & folder1.DateLastModified & vbCrLf
    '获取文件夹的大小
    sReturn = sReturn & “The folder's size is " & FormatNumber(folder1.Size / 1024, 0)
    sReturn = sReturn & “Kb" & vbCrLf
    '判断文件或文件夹类型
    sReturn = sReturn & “The type is " & folder1.Type & vbCrLf
    MsgBox sReturn
    End Sub

  • 相关阅读:
    html5 audio vedio and video.js
    webpack的require是如何工作的?
    webpack HMR是如何工作的?
    vuejs code splitting with webpack 3种模式
    how webpack Hot Module Replacement works
    C# checkedlistbox 控件 有bug
    C# DataGridView 更改类型 重绘
    C# webapi
    C# 遍历控件名称
    C# 转json
  • 原文地址:https://www.cnblogs.com/spider518/p/1917485.html
Copyright © 2011-2022 走看看