各种计算机语言简介和总结 版本:v1.1 Crifan Li 摘要 本文主要介绍了各种计算机语言的分类和关系,以及记录了笔者对其中部分语言,如Word VBA,Excel VBA,Python,C++,Javascript,C#等,的心得和体会。 [提 本文提供多种格式供: 示] 在线阅读 HTML HTMLs PDF CHM TXT RTF WEBHELP 下载(7zip压缩包) HTML HTMLs PDF CHM TXT RTF WEBHELP HTML版本的在线地址为: http://www.crifan.com/files/doc/docbook/language_summary/release/html/ language_summary.html 有任何意见,建议,提交bug等,都欢迎去讨论组发帖讨论: http://www.crifan.com/bbs/categories/language_summary/ 2015-05-07 ┌─────────────────────────────────────────────────────────────────────────────┐ │修订历史 │ ├─────────────────────────────┬────────────────────────────────────┬──────────┤ │修订 1.1 │2015-05-07 │crl │ ├─────────────────────────────┴────────────────────────────────────┴──────────┤ │ 1. 完成此文逻辑框架 │ │ 2. 添加如何在Windows下的cmd环境下使用Python脚本 │ │ 3. 添加了C++的内容 │ │ 4. 添加了Javascript的内容 │ │ 5. 添加了Word VBA的内容 │ │ 6. 添加了Excel VBA的内容 │ │ 7. 添加了Python的内容 │ │ 8. 添加了C#的内容 │ │ 9. 添加了Python的crifanLib.py的全部内容 │ │10. 添加了C#的crifanLib.cs的全部内容 │ │11. 添加了Python的BeautifulSoup心得 │ │12. 已将Python移出至单独的book │ │13. 已将C#移出至单独的book │ │14. 添加为何高级语言不能直接操作硬件 │ └─────────────────────────────────────────────────────────────────────────────┘ 版权 © 2015 Crifan, http://crifan.com 本文章遵从:署名-非商业性使用 2.5 中国大陆(CC BY-NC 2.5) ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ 目录 1. 各种计算机语言简介 1.1. 各种计算机语言简介 2. 脚本语言 2.1. 脚本语言综述 2.2. Python语言总结 2.3. Word VBA 2.3.1. 什么是word vba?为何要用VBA? 2.3.2. Word VBA的一些基本概念 2.3.3. Word vba学习记录 2.3.4. 授人鱼不如授人以渔 2.4. Excel VBA 2.4.1. Excel VBA中基本的名词和概念 2.4.2. Excel VBA中的一些基本操作 2.4.3. Excel VBA更多的学习资料 2.4.4. 授人鱼不如授人以渔 2.5. Javascript 2.5.1. javascript学习记录 2.6. PHP 2.6.1. PHP学习记录 2.6.2. crifan的PHP库 2.6.2.1. 与字符串等有关的函数 2.6.2.1.1. 添加末尾的斜杠:addTailSlash 2.6.2.1.2. 去除开始的斜杠:removeFirstSlash 2.6.2.1.3. 检查一个字符串是否在另一个数组中:strExistInArr 2.6.2.1.4. 从文件过滤类型生成文件后缀列表:genValidSuffix 2.6.2.2. 与文件等有关的函数 2.6.2.2.1. 获得文件名的后缀:getFileSuffix 2.6.2.2.2. 如何获得某个文件下面的文件(和子文件夹) 2.7. Linux Shell 2.7.1. Linux Shell学习心得 2.7.2. Linux Shell参考资料 2.8. Windows Batch File 2.8.1. Windows Batch File简介 2.8.2. Windows Batch File学习心得 2.8.3. Windows Batch File参考资料 3. 上层语言 3.1. 上层语言综述 3.2. C#学习心得 3.3. C++ 3.3.1. C++学习笔记 3.4. 为何高级语言不能直接操作硬件? 4. 网络相关的语言 4.1. XML 4.1.1. XML相关的参考资料 4.2. HTML 4.2.1. HTMl学习心得 4.2.2. HTML相关的参考资料 参考书目 表格清单 3.1. protected,public,private之间的区别 范例清单 2.1. addTailSlash使用范例 2.2. strExistInArr使用范例 2.3. genValidSuffix使用范例 2.4. getFileSuffix使用范例 第 1 章 各种计算机语言简介 目录 1.1. 各种计算机语言简介 摘要 1.1. 各种计算机语言简介 第 2 章 脚本语言 目录 2.1. 脚本语言综述 2.2. Python语言总结 2.3. Word VBA 2.3.1. 什么是word vba?为何要用VBA? 2.3.2. Word VBA的一些基本概念 2.3.3. Word vba学习记录 2.3.4. 授人鱼不如授人以渔 2.4. Excel VBA 2.4.1. Excel VBA中基本的名词和概念 2.4.2. Excel VBA中的一些基本操作 2.4.3. Excel VBA更多的学习资料 2.4.4. 授人鱼不如授人以渔 2.5. Javascript 2.5.1. javascript学习记录 2.6. PHP 2.6.1. PHP学习记录 2.6.2. crifan的PHP库 2.6.2.1. 与字符串等有关的函数 2.6.2.1.1. 添加末尾的斜杠:addTailSlash 2.6.2.1.2. 去除开始的斜杠:removeFirstSlash 2.6.2.1.3. 检查一个字符串是否在另一个数组中:strExistInArr 2.6.2.1.4. 从文件过滤类型生成文件后缀列表:genValidSuffix 2.6.2.2. 与文件等有关的函数 2.6.2.2.1. 获得文件名的后缀:getFileSuffix 2.6.2.2.2. 如何获得某个文件下面的文件(和子文件夹) 2.7. Linux Shell 2.7.1. Linux Shell学习心得 2.7.2. Linux Shell参考资料 2.8. Windows Batch File 2.8.1. Windows Batch File简介 2.8.2. Windows Batch File学习心得 2.8.3. Windows Batch File参考资料 摘要 2.1. 脚本语言综述 脚本语言综述 2.2. Python语言总结 关于Python语言总结,已移至这里:Python语言总结 2.3. Word VBA 2.3.1. 什么是word vba?为何要用VBA? VBA是Visual Basic For Application的简称。 换句话说,就是将VB应用于Application应用程序,此处的Application指的是微软的Excel ,word等应用程序。 所以,对于我用到的,在word里面写宏,去实现一些操作,用到的VB,就是Word VBA了。 而其他常用的,还有Excel里面也会用到用宏去实现一些根据自己需求实现的一些功能,比 如自动提取一些内容到一个文档中,否则,自己手动慢慢地复制粘贴,往往效率极低,累 死你不说,还不容易保证完全正确,而通过宏来处理,运行一下宏,点击一下某个菜单等 ,即可实现要做的事情,高效,准确。 就像别人说的,除了"Excel本身的内置函数其实已经很强大了",但是只是很强大,有些更 高级或复杂的操作,还是宏实现起来更方便和快捷。 再简而言之,如果你不是需要对某(些)文档特殊处理,只是一般的使用word或excel文档 ,多数人都是用不到的。 而如果有类似于我这样的需求,将某个word文档中的很多表格中的符合某些特定条件的某 些列的内容,经过一定条件判断,将对应的值提取到一个xml文档中,并且输出的时候,要 将该值根据某些约定,再分成几个部分等等,这类的操作,手动实现,要一个个去找对应 的表格,然后找到对应的值,然后手动复制,粘贴,一点点做,效率很低,而如果可以用 宏实现,只需要写好宏代码,运行一下,即可省去大量的精力。 不过,就像[2]说的:"VBA功能很强大,但并不是万能的,也并不是所有工作都需要用VBA 来解决,也并不是所有工作用VBA来解决都会很简单,这要根据实际情况而定,有些工作你 用VBA来解决的话相反会变得很麻烦。" 2.3.2. Word VBA的一些基本概念 此处介绍一下,Word VBA中的一些基本单位(名词):story, section, paragrah, line, character,table,cell,row, column 对于所选一段文字后,即引用Selection,其中会包含很多属性,Selection.XXX 其中XXX 就有下面列出来的很多种,现在简单说说我对这些属性含义的理解: 1. Story 中文直译为故事,经过测试,感觉对于word文档来说,好像就是整个文档的内容。 2. Text 不必多解释,就是所选的内容 3. Sections 节。经测试,好像整个word文档,就一个节,有点像story,具体两者的区别,暂未搞 懂。 4. Paragraphs 段落。按照中文的段落的含义理解,怎么说也应该有个几十行之类的文字,才算一个 段落的,这是之前学语文的时候的感觉。结果发现这里的段落和中文意思的段落,差 别很大,一个文档里面,没多少行字,结果段落就几百个了,貌似是一个单词,一个 换行,一个表格中的值,都算一个段落。 5. Sentences 句子,同常理,不多解释。 6. Words 单词,同常理,不多解释。 7. Characters 字符,同常理,不多解释。 8. Tables,Cells,Rows,Columns 表格,同常理。其中包含了很多个cell,即单元格。每个cell,都对应不同的行和列 。 (打印)输出所选Range中(其包含很多个表格)中的第二个表格中的第三行第四列的 值,表示为: Print Selection.Tables(2).Cell(3, 4) [注 注意 意] 其中第三行第四列,不是Cell(2,3),因为其单元格的下表是从1开始,而不是原 以为的类似于C语言或者Excel中的0为起始值的。 9. End ,Start 即Selection.Start和Selection.End ,都是直接赋值的 所以,如果你想要选中某段内容(文字),那么只要找到你所要的起点和终点,然后 将其值赋值给Selection.Start和Selection.End,即可选中该段内容(文字)。 当然,也可以利用两者算出所选内容的长度: slection_len = Selection.End - Selection.Start 10. 2.3.3. Word vba学习记录 1. 获得所选range的文字 尝试了一下,发现两种都可以: Selection.Text Selection.Range.Text 2. 不等于符号 VBA里面的不等于号,用"<>"表示,而不是其他C等语言里面的"!=" <>,即大于号和小于号的组合,意思也很明确,既不大于也不小于,所以就是不等于 了。 3. 如何选中一行并获得对应的文字和 wdMove和wdExtend的区别 前提,光标(或叫插入点)已经移动到该行了,但是想要选中该行,并想要获得对应 所选Range的文字 此时可以用如下代码: Selection.MoveDown Unit:=wdLine1, Count:=1, Extend:=wdExtend2 1 wdLine是单位(Unit) 类似的Unit还有:wdParagraph,wdWindow,wdScreen。 2 和WdExtend对应的还有wdMode 对此,VBA教程的解释是:“如果是 wdMove,则所选内容折叠到结束位置,并向 下移动。如果是 wdExtend,则所选内容向下扩展。默认值为 wdMove。” 没完全理解,但是经过测试得知,如果是mdMove,那就是光标移动到对应位置了 ,但是没有选择这(光标移动的)起点到终点,此处为整个这一行,的内容,如 果是wdExtend,那就是不仅移动光标了,并且同时选中了起点到终点的内容。 4. 如何跳转到某一标题和如何移动光标/插入点 Selection.GoTo1 What:=wdGoToHeading2, Which:=wdGoToAbsolute3, Count:=5 1 这里主要是利用Goto语句 2 wdGoToHeading说明掉转的单位是heading标题 3 wdGoToAbsolute表示是绝对位置的跳转 于此相对应的还有wdGoToFirst, wdGoToLast, wdGoToNext, wdGoToPrevious, wdGoToRelative。 更多详细内容,请参考[3] 另外,对于移动光标/插入点,可以借鉴如下做法: 本示例将所选内容移至当前文字部分的开头。如果所选内容位于文档正文部分, 则本示例将所选内容移至文档的开头 Selection.HomeKey Unit:=wdStory1, Extend:=wdMove 1 wdStory属于wdUnits 其他类似的还有wdColumn,wdLine,wdRow等 5. 如何获得选中的标题的序号 前提,已经选择某一标题了,想要获得该标题前面的序号 比如对这个标题: 2.1 PAPRBY / RubyVerifoneDefaults 想要获得标题的序号,即2.1 可通过下列代码获得当前标题的序号,即2.1 Selection.Bookmarks("\headinglevel1").Range.ListFormat.ListString 1 \headinglevel是VBA里面的预定义标签 关于此内容的详细解释,请参考:[5] 6. 如何返回函数的返回值 关于这点,网上找,没几个说的很清楚的,最后还是通过VBA的Help才搞懂如何返回函 数返回值的。 此处,简单解释如下: 一个Function函数的语法为: [Public | Private | Friend] [Static] Function name1 [(arglist)] [As type] [statements] [name = expression2] [Exit Function] [statements] [name = expression]3 End Function 1 name即为函数名 2 expression是表达式,当然也可以是某个变量,常量等,其就代表了返回值。 更具体的解释和例子,摘录如下,很容易看懂的: 要从函数返回一个值,只需将该值赋给函数名。在过程的任意位置都可以出 现这种赋值。 如果没有对 name 赋值,则过程将返回一个缺省值:数值函数返回 0,字符 串函数返回一个零长度字符串 (""),Variant 函数则返回 Empty。 如果在返回对象引用的 Function 过程中没有将对象引用赋给 name (通过 Set),则函数返回 Nothing。 下面的示例说明如何给一个名为 BinarySearch 的函数赋返回值。 在这个示例中,将 False 赋给了该函数名,表示没有找到某个值。 Function BinarySearch(......) As Boolean ...... '值未找到,返回一个 False 值。 If lower > upper Then BinarySearch = False Exit Function End If ...... End Function 看懂后,多说一句,有问题,还是先找VBA的Help系统,比百度,google等,有 时候更准确,方便,易懂。 3 函数内部任何地方都可以出现[name = expression] 7. 字符串处理函数 关于VBA中的字符串相关的函数,刚发现,office 2010 中的 VBA的help文件里面,有 已经总结好的了: 作用 关键字 比较两个字符串 StrComp 变换字符串 StrConv 大小写变换 Format, LCase, UCase 建立重复字符的字符串 Space, String 计算字符串长度 Len 设置字符串格式 Format 重排字符串 LSet, RSet 处理字符串 InStr, Left, LTrim, Mid, Right, RTrim, Trim 设置字符串比较规则 Option Compare 运用 ASCII 与 ANSI 值 Asc, Chr 上述字符串处理相关的函数,多数都是见名知意,容易看懂和使用,但是也有些不太 容易搞懂,或者和普通C语言等里面的字符串处理函数不同的,需要额外说明的,解释 如下: a. Space, String 其中Space很方便,比如想要输出10个空格,当然你可以通过自己手动的写成" " ,但是有了space,用其更方便,直接写成 Space(10) 即代表了10个空格。同理 String(number,characterToRepeate) 用于输出多个某一字符,而对于前面的空格来说,也可以用string表示,即 Space(10)=String(10, 32) 其中32=0x20,是space的ASCII值。而String的优点在于,也可以输出其他字符, 包括0x0~0x1F之类不可见字符。 b. InStr, InStrRev 这个InStr,其实就是C语言的strstr 语法为: InStr([start, ]string1, string2[, compare]) 意思为:"返回 Variant (Long),指定一字符串在另一字符串中最先出现的位置 。" 而InStrRev意思和InStr类似,只不过是"从字符串的末尾算起"。 举例说明: posOfPoint = InStr("abc.def", ".") ’ 查找"abc.def"中的".",返回值为4 c. Asc, Chr Asc是将字符转换为ASCII数值,Chr是将数值转换为ASCII字符。 举例为: MyNumber = Asc("A") ' 返回 65。 MyChar = Chr(97) ' 返回 a。 d. 如何创建文件和输出信息到文件里面 在VBA中创建(log)文件的两种方法.  i. 方法1: Function createFileTest() ' the name of the file to be output, including full path Dim FileName As String FileName = "D:\create_file.txt" ' open the file ouput text stream output, overwritng is necessary Dim fs As Object Set fs = CreateObject("Scripting.FileSystemObject") Dim file As Object Set file = fs.CreateTextFile(FileName, True) file.WriteLine "test string..." file.Close End Function ii. 方法2: Public gFileNum As Integer Function createOutputFile() Dim outputFileNameWithPath As String Dim gDestFile As String Dim outputFileNameWithPath As String Dim openFileOK As Boolean openFileOK = True ' 1. create an XML file outputFileNameWithPath = "D:\test_output.txt" gDestFile = outputFileNameWithPath ' Obtain next free file handle number. gFileNum = FreeFile() ' Turn error checking off. On Error Resume Next ' Attempt to open destination file for output. Open gDestFile For Output As #gFileNum ' If an error occurs report it and end. If Err <> 0 Then openFileOK = False MsgBox "Cannot create file: " & gDestFile End If ' Turn error checking on. On Error GoTo 0 createOutputFile = openFileOK End Function Sub createFileTest() Print #gFileNum, "Test output string to this file..." Print #gFileNum, "Test done." Close #gFileNum End Sub e. 如何获得当前文件的文件名和当前文件所在路径 i. 获得当前文件所在的路径:ActiveDocument.Path。 注意:所得结果,最后没有那个路径分隔符"\" ii. 获得当前文件的文件名:ActiveDocument.Name iii. 获得当前文件的路径和文件名,即全名:ActiveDocument.FullName f. VB里面的一些常量 office 2010的help文件里面已有总结: Visual Basic 常数 Visual Basic for Applications 定义了一些常数,使程序设计变得更为简 单。下列常数可在程序代码中的任何地方代替实际值: ○ Calendar 常数 ○ CallType 常数 ○ Color 常数 ○ Compiler 常数 ○ Date 常数 ○ Dir、GetAttr 和 SetAttr 常数 ○ IMEStatus 常数 ○ Instr、StrComp 常数 ○ Keycode 常数 ○ Miscellaneous 常数 ○ MsgBox 常数 ○ QueryClose 常数 ○ QueryClose 常数 ○ Shell 常数 ○ StrConv 常数 ○ 系统颜色常数 ○ VarType 常数 ○ Visual Basic 常数 其中,此处打算把一些我所常用到的一些常数列出来,以供参考 Miscellaneous 常数 下列常数由 Visual Basic for Applications 中的类型库定义,可用来在代 码中的任何地方代替实际值 常数 等于 描述 vbCrLf Chr(13) + Chr(10) 回车符与换行符结合 vbCr Chr(13) 回车符 vbLf Chr(10) 换行符 Chr(13) + Chr(10) 平台指定的新行字符;适用于当前平 vbNewLine or, on the 台 Macintosh, Chr(13) vbNullChar Chr(0) 值为 0 的字符 vbNullString 值为 0 的字符串 用来调用外部过程;与长度为零的字 符串 ("") 不同 用户定义的错误号应当大于该值,例 vbObjectError -2147221504 如:Err.Raise Number = vbObjectError + 1000 vbTab Chr(9) Tab 字。 vbBack Chr(8) 退格字符 vbFormFeed Chr(12) 在 Microsoft Windows or on the Macintosh 中没有作用 vbVerticalTab Chr(11) 在 Microsoft or on the Macintosh Windows 中没有作用 2.3.4. 授人鱼不如授人以渔 下面介绍一些更多有用的参考资料,以及介绍一下遇到问题如何去解决问题。 1. 通过VBA内置的Help系统查询不懂的内容 在word里面打开VBA编辑器编辑vba代码后,对于常见的一些对象,属性,方法(函数 )等的具体解释,多数都可以通过选择该对象/属性/方法,然后按F1键,打开帮助, 其会自动跳转到对应的帮助内容,很是方便,而且很多的细节,解释的也比较详细, 可以多多利用。 其中都包括了一些基本知识的详细解释,比如上面提到的,关于VBA中关于Function的 返回值,其要去查看Help文件,就可以通过选择某函数, 比如,选中: Function funcName() 'XXXXXX End Function 中的Function,然后按F1键,系统自动会跳转到Help文件中关于Function的解释,很 方便。 2. 常见函数分类列表 office 2010中VBA的help文件做的很好,里面总结了一些常见的函数,前面列出来的 ,就是那个字符串处理相关的函数。 下面列出了,其他一些类别,先放到这里,以备后查: 分类 描述 数组 建立、定义与使用数组 编译命令 控制编译方式 控制流 循环及过程流程控制 变换 变换数值及数据类型 数据类型 数据类型与 variant 子型态 日期与时间 变换、使用日期与时间表达式 目录和文件 控制文件系统与处理文件 错误 侦测与返回错误值 金融 进行各种金融运算 输入与输出 接受输入与显示、打印输出 数学 完成各种数学运算 其他 激活其他应用程序与处理事件 操作符 比较表达式与完成其它操作 字符串处理 处理字符串及字符串数据类型 变量与常数 声明、定义变量与常数 3. 网上在线查找相关帮助内容 刚找到的,微软的官方的在线帮助: http://office.microsoft.com/zh-cn/access-help/CH010072891.aspx?CTT=97 2.4. Excel VBA 看此部分内容之前,关于VBA的基础知识,以及word VBA的相关知识,可参考第 2.3 节 “Word VBA” 2.4.1. Excel VBA中基本的名词和概念 此处介绍一些Excel中的最基本的概念,搞清楚这些概念,是继续深入学习Excel的基础。 Excel中,我们已经知道的是,从概念上来说,从大到小是: Excel文件 ⇒ Excel文件中页表sheet ⇒ sheet中的行和列 ⇒ 行列交叉点所对应的单元格 这些名词和概念,对应到Excel VBA中就是: Workbook ⇒ Worksheet ⇒ Column, Row ⇒ Cell 并且,每个概念,都对应着一个该单词的复数形式,表示的是对应的一组的该单位, 如:Workbooks表示一组,很多个当前已经打开的Excel文件等。 下面稍微详细地介绍一下各自的含义和用法。 1. Workbook workbook属于workbooks,workbooks是当前打开的所有的workbook的集合(总称)。 对于想要获得单个的workbook,有这些方式: □ Workbooks.Item(N) □ Workbooks(N) □ Workbooks("excel_file_name.xlsx") Workbook所具有的一些常见函数有: □ Workbook.Open □ Workbook.Add □ Workbook.Save □ Workbook.SaveAs 对于其更多的函数和属性,细心的人,自然会想到利用前面提到的自学方法,去更加 详细的学习了解的。以后对此类提示,就不再多提醒了。 2. Worksheet worksheet即我们常说的Excel中sheet。 worksheet属于worksheets。 Excel软件,创建一个Excel文件的时候,默认会自动创建3个sheet,对应的就是该 workbook的worksheets,包含了3个worksheet。 对应获得当前的worksheet的方式: □ Workbooks.Item(1).Sheets.Item(N) □ Workbooks.Item(1).Sheets.Item("sheet_name") 3. Column 对应的概念很好理解,不多解释。 对应每个列,都有一个自己的名字,比如第三列,名字一般是"C"。 获得第三列的方式有: □ Columns(3) □ Columns("C") 获得3到5列,可以: □ Columns("C:E") □ Range("C:E") 选中1, 5,7,8,9列: Range("A:A, E:E, G:G, H:H,I:I").Select 设置宽度: Columns("C").ColumnWidth = 4.5 大小自动适应: Selection.Columns.AutoFit 隐藏显示某列用对应的: Columns("C").hidden=True 4. Row 行的操作,非常类似于列的操作: 选中2到6行: Rows("2:6").Select 选中第一行: Rows(1).Select 选中5,7,8行: Range("5:5, 7:7,8:8").Select 设置行高: Rows(6).RowHeight = 2.5 选中某6行,将其隐藏: Rows("6:6").Select Selection.EntireRow.Hidden = True [提 可以通过行Row或列Column的名称来操作行或列 示] 另外,如果单独对于某列,比如第三列,默认名字,是"C",可以同选中该列,鼠 标移动到左上角那个输入框中,鼠标会自动显示"Name Box",此时你可以在里面 输入你想要的名字,比如"Col3",然后接下来的所有的对第三列的操作和引用, 之前是通过Columns("C")来获得的,现在就可以通过 Columns("Col3") 来操作了。 即Columns("XXX")中的XXX是对应的列的名字。 对于行的操作,也是同样适用的。 即可以先去对某行去命名,然后就可以通过对该名字来引用到该行了。 5. Cell 行和列交叉点,对应的就是单元格cell。 下面是各种操作: 第四列第六行: Range("D6") 设置单元格的一些属性: Range("B3″).Font.Name = "Cambria" ‘也可以设置为宋体,微软雅黑 Range("B3″).Font.Bold = True 选中从D2到H6的整块的单元格: Range("B2:H6") 用同样的方式去选中某个单个的单元格: Range("D4:D4") 选中两块单元格: Range("B2:C5,EC4:G8").Select 选中部分重叠的两块单元格: Range("B2:C5, C4:G8").Select 取消显示网格线: ActiveWindow.DisplayGridlines = False 2.4.2. Excel VBA中的一些基本操作 1. 如何添加注释 VBA中的注释,是以单引号"'"开头的,其后内容,都视为注释内容。 另外一种,也可以通过关键字REM或Rem加上个空格,之后的内容,也会被识别为注释 。 比如: REM this is a excel maro ' this is a excel maro 2. 如何调试 简单的说,有两种方式: a. Msgbox 一是直接调用Msgbox去弹出对话框打印信息。 比如: MsgBox "Currently opening Excel file is: " & ActiveWorkbook.Name 其中,字符串链接/拼接,用&符号。 b. log文件 二是新建一个log文件,将调试或打印信息输出到log文件中去。 关于如何创建文件,可参考:在VBA中创建(log)文件的两种方法 3. 获得当前的Excel文件所在路径 类似于Word VBA中的ActiveDocument,Excel中是ActiveWorkbook 所以获得当前打开的Excel的文件路径是: ActiveWorkbook.Path 与此相关的是: ActiveWorkbook.FullName = ActiveWorkbook.Path + '' + ActiveWorkbook.Name 更多相关的内容,请自己尝试: □ MsgBox ActiveWorkbook.Name □ MsgBox ActiveWorkbook.FullName □ MsgBox ActiveWorkbook.FullNameURLEncoded □ MsgBox ActiveWorkbook.Path 4. 一些通用的属性和方法(函数) 对于选中当前的内容,比如workbook,sheet等,可以通过.Select来选中, 比如: Sheets("sheet_name").Select 对于当前的内容的名字,对应的是.Name属性,比如: Sheets("sheet_name").Name 很多内容,都有move的功能,详细用法请自己探索。 新增一个新的内容,比如workbook,sheet等,都可以用Add方法。 2.4.3. Excel VBA更多的学习资料 1. VBA for Microsoft Office Excel 2007 关于Excel VBA的一些基础知识,可以去看这里: VBA for Microsoft Office Excel 2007 2. Excel 2007 VBA参考大全 关于Excel VBA,这本书介绍的很全: 《Excel 2007 VBA参考大全》扫描版 [PDF] 电驴地址: ed2k://|file| %5BExcel.2007.VBA%E5%8F%82%E8%80%83%E5%A4%A7%E5%85%A8%5D.%EF%BC%88%E7%BE%8E%EF%BC%89%E6%A0%BC%E6%9E%97.%E6%89%AB%E6%8F%8F%E7%89%88.pdf |253406092|3cf57fc49d0fa875826ecc462cd9976c|h= eed6g2e25uuzc4c52obch2txlm7w65fx|/ 2.4.4. 授人鱼不如授人以渔 此部分内容,其实在之前第 2.3 节 “Word VBA”中,已有提到,此处再次强调一下。 在学习VBA(和任何类似知识)的过程中,学会利用系统已有资源。 即,在VBA中,可以供我们利用的资源,至少有这些: 1. VBA中的对象浏览器(Object Browser) 可以通过在写VBA代码的过程中,对于任何你不太懂,想要了解更多细节的内容,选中 该内容,比如我想要了解workbook,那就选中workbook,然后右键⇒Object Browser, 即可在Object Browser中查找到你所要的内容,其中可以直观快速地看到对应目标所 具有的变量成员和函数等,很是方便。 2. 内置的Help 选中想要查询的内容,然后按F1,VBA即可调用Help帮助系统,可以查询到更多的细节 和实例用法。 例如,我知道了workbook是对应于当前Excel文件,想要了解workbook有哪些属性和方 法, 那么可以去F1的Help中输入workbook,然后搜索到很多条目,其中第一条就是: Workbook Object Members “Article Represents a Microsoft Excel workbook. Methods Name Description AcceptAllChanges Accepts all changes in the specified shared workbook. Activate Activates the fi...” 然后点击进入后,就可以看到"Workbook Object Members"的页面,其中有三部分: Methods,Properties,Events 里面有你想要的所有的成员和函数等。 比如,表示当前Excel的文件名的.Name的属性,文件全名(包括路径和文件名) 的.FullName的属性等。 然后你也可以通过Msgbox去自己尝试打印出来看看,都是什么值: MsgBox ActiveWorkbook.Name MsgBox ActiveWorkbook.FullName 这样的话,你就可以可以通过自学的方式,去搞懂很多内容了。 3. 通过录制宏去照葫芦画瓢 如果还是不会操作,那么可以去通过VBA提供的录制宏的功能,来实现搞懂VBA系统是 如何将你对应的操作转化为对应的VBA代码的,然后你就可以照葫芦画瓢了。 比如,我打开两个Excel文件,将其中一个Excel中的某个单元格的内容,选中后复制 ,然后切换到另外一个Excel文件,选中某个单元格,按了Ctrl+V粘贴,然后按了 Ctrl+S来保存,如此这段操作,通过录制宏,得到如下代码: Sub Macro3() ‘ ‘ Macro3 Macro ' Range("B3″).Select Selection.Copy Windows("EWR_tracking_list_enabledMacro.xlsm").Activate Range("O152″).Select ActiveSheet.Paste Application.CutCopyMode = False ActiveWorkbook.Save Windows("ROSH1.xlsx").Activate End Sub 所以,如果你想要实现类似的操作,至少是复制粘贴等动作,就可以参考上述代码了 。 [提 Excel中如何录制宏 示] View⇒Macro⇒Record Macro,跳出对话框让你输入要录制的话宏的名称,随便起个 名字,然后你就可以去随心所欲地操作了, 操作完成后,再去View⇒Macro⇒Stop Macro,即可。 此时,再去View⇒Macro⇒View Macro去查看你刚录制的宏,即可看到对应的VBA代 码。 通过上述方法,基本上大部分内容,都可以自己自学而搞懂。 有人会问,那么我最开始使用VBA的话,连一些基本概念和其他一些常见操作都不会,连对 应的关键字都不知道,那么又如何去查询对应关键字呢? 答案是,学会利用baidu和google,可以查询你要实现的操作,往往都会找到相关内容的, 即使没有找到直接的答案,但是也可以找到对应的相关的关键字,然后就可以通过上述 Object Browser和F1的Help,找到更多的细节的用法,如果足够细心和能够举一反三,相 信很多的内容,都可以自己发掘并实现的。 如果还是没搞懂,普通的操作,也是可以通过录制宏的方式,然后去实际操作,最后查看 所录制的宏的代码中,是如何操作的,你就可以照葫芦画瓢了。 2.5. Javascript 2.5.1. javascript学习记录 1. 但是实际上看到一些网页,比如: http://hi.baidu.com/recommend_music/blog/item/5fe2e923cee1f55e93580718.html 的html源代码中,script没有指定type: 一直很奇怪,为何可以用。 后来终于找到解释了: http://blog.csdn.net/slalx/article/details/5093756 二.指定脚本语言的方式: 1.指定整个文档默认的脚本语言。 content:指定脚本语言的类型如:"text/tcl", "text/javascript", "text/ vbscript". 由于文档默认的脚本类型是JavaScript,因此我们在使用JavaScript时最简单且 兼容性最好的方式为 不过,即使如此,还是没在上面那个网页的html源码中,看到有期望的: 估计是该网页的javascript写的不够严谨吧。 2. 关于字符串的format函数 参考这里: http://witmax.cn/js-function-string-format.html 举例用法: return "{2}".format(portraitId, cmturl, cmtname); 其中,{0},{1}.{2}分别代表format后面的参数的第一个,第二个,第三个。 3. 打印或枚举出一个变量的所有属性property,或一个字典的所有键(key)和值( value) a. 打印或枚举出一个变量(对象)的所有的属性property 参考这里: http://blog.csdn.net/sd2131512/article/details/6328300 知道了,可以这样写: for(var name in someObject){ document.write(name + "=" + someObject[name]) } 此处someObject是某个对象变量,然后上面的for语句,加上"变量[属性]"的方式 ,可以获得所有的变量,并打印出来。 b. 打印或枚举出一个字典的所有键key和值value 参考这里: http://www.w3schools.com/JS/js_loop_for_in.asp 后经过测试,下面代码在IE9里面可以运行: var arrayData = { a : "11", b : "22", c : "33", d : "44" } for (__key in arrayData) { document.write( __key + "=" + arrayData[__key]) } 其中上面的arrayData是一个字典,然后也是通过"字典[键]"的方式,获得对应键 的值 4. 如果某一行javascript脚本出错,则执行结果出错,但是却没有任何提示 最新在折腾【记录】折腾给WordPress Google XML Sitemap中添加支持子目录自动扫 描功能,包含HTML静态页面等可识别的格式的过程中,发现一个现象: html或php页面中,出现了非所预料的结果,知道是代码某处写错了,但是不值得是哪 个文件的哪一行错了。 最后才无意间发现,原来是某个js脚本中,之前添加的多余的注释TODO字符串,没有 及时删除,导致页面结果出错。 由于感慨,js代码执行结果异常,某行出错了,也没有任何的提示和警告,导致最终 结果虽然错了,也知道是代码问题,但是却无法定位错误的位置。 如此去调试html,php,javascript混合的页面,真的很痛苦。 期待高手可以指教指教,有没有更加有效的调试方法。 5. 如果改动了javascript中的内容,一定要刷新页面,才可以看到最新改动的效果!! ! 最新在折腾【记录】折腾给WordPress Google XML Sitemap中添加支持子目录自动扫 描功能,包含HTML静态页面等可识别的格式的过程中,在修改对应的javascript文件 sitemap.js,但是,始终却不见修改后的效果。 但是很奇怪的是,之前对于HTML页面等内容,修改了后,点击对应选项,是可以看到 最新的改动的效果的。 而此处不论如何改动js文件,结果都不见效果。 最后,才发现,原来对于js文件,需要重新刷新HTMl页面,其会重新加载最新的js文 件,然后才能看到最新的效果。 而之前不知道这一点,真的是浪费了非常非常多的时间。 2.6. PHP 2.6.1. PHP学习记录 1. 2. 2.6.2. crifan的PHP库 暂时还没有合并所有的php相关的函数到crifanLib.php中,此处只是整理出目前已有的一 些有用的函数而已。 2.6.2.1. 与字符串等有关的函数 2.6.2.1.1. 添加末尾的斜杠:addTailSlash //add the tail slash if not exist //eg: from files/doc/docbook to files/doc/docbook/ function addTailSlash($str) { if(substr($str, -1) != "/") { $str = $str."/"; } return $str; } 例 2.1. addTailSlash使用范例 //add tail slash $homePath = $this->addTailSlash($homePath); //echo "homePath=".$homePath."
"; 2.6.2.1.2. 去除开始的斜杠:removeFirstSlash //remove the first slash if exist //eg: from /files/doc/docbook to files/doc/docbook function removeFirstSlash($str) { if(substr($str, 0, 1) == "/") { $str = substr($str, 1); } return $str; } 2.6.2.1.3. 检查一个字符串是否在另一个数组中:strExistInArr //eg: check txt is in array("txt", "html", "pdf") function strExistInArr($str, $arr) { if($arr[0] == "*") { $found = True; } else { $found = False; $arrLen = count($arr); for($i=0; $i<$arrLen; $i++) { //if(0 == strcmp($str, $arr[$i])) if($str == $arr[$i]) { $found = True; break; } } } return $found; } 例 2.2. strExistInArr使用范例 $fileValid = $this->strExistInArr($fileSuf, $validSuf); 2.6.2.1.4. 从文件过滤类型生成文件后缀列表:genValidSuffix //eg: from "*.html;*.txt;" to array("html", "txt") function genValidSuffix($fileType) { $validSuf = array(); $splitedArr = explode(";", $fileType); $arrSize = count($splitedArr); //echo "splited arrary size=".$arrSize."
"; for($i=0; $i<$arrSize; $i++) { $singleSufDef = $splitedArr[$i]; //echo "singleSufDef=".$singleSufDef."
"; if($singleSufDef && ($singleSufDef != "")) { //echo "singleSufDef not null
"; $suffix = str_replace("*.", "", $singleSufDef); //echo "suffix=".$suffix."
"; if($suffix == "*") { //echo "found & suffix
"; $validSuf = array("*"); break; } else { //echo "add $suffix into array
"; array_push($validSuf, $suffix); } } } return $validSuf; } 例 2.3. genValidSuffix使用范例 //$validSuf = array("html", "htm", "txt", "pdf"); $validSuf = $this->genValidSuffix($fileType); 2.6.2.2. 与文件等有关的函数 2.6.2.2.1. 获得文件名的后缀:getFileSuffix //eg: from abc.txt got txt function getFileSuffix($fileName) { $gotInfo = pathinfo($fileName); // dirname, basename, extension $suffix = strtolower($gotInfo["extension"]); return $suffix; } 例 2.4. getFileSuffix使用范例 $fileSuf = $this->getFileSuffix($filename); 2.6.2.2.2. 如何获得某个文件下面的文件(和子文件夹) 相关的代码如下,供参考: $dirHandler = opendir($fullPath); while(($filename = readdir($dirHandler)) !== false) { if(($filename == ".") || ($filename == "..") ) { //echo "omit filename=$filename"; continue; } echo "filename=". $filename"; } closedir($dirHandler); 2.7. Linux Shell 2.7.1. Linux Shell学习心得 1. 递归函数中的变量值被下层调用所修改的问题 由于Linux shell中默认定义的变量都是全局的,所以导致在递归函数中定义的变量, 在下一层调用中修改了值后,返回上一层,改变量已被修改,导致运行结果不对。 解决办法就是,给相应的变量加上local前缀,表示是局部变量,即可。 详情参看:【已解决】Linux Shell中,递归函数调用过程中,变量的值被改变,即下 层调用会影响上层中的变量的值 2. ./xxx.sh: line xx: [: too many arguments 问题原因:参数太多 比如,使用 if [ -d $item_full_path ]; then 去判断item_full_path是否为文件夹,但是如果传入的参数是 arm_vs_mips.xml - Copy_bak ,则会出现too many arguments的错误。因为对于shell中的-d去判断一个参数是否为 文件夹的时候,此参数,只能是一个字符串,而不能是多个字符串,而此处的 arm_vs_mips.xml - Copy_bak 虽然物理上表示对应的某个文件,但是作为此处的参数传递进来的话,的确就是三个 字符串了: arm_vs_mips.xml - Copy_bak 。 解决办法:自己去找错误的位置,是不是也是由于类似的,使用某个功能的时候,传 递的参数,超过该功能所期望的参数的个数了。如果超过了,估计多数情况下,也都 是你自己使用不当,或者没有进行合适的处理而导致的。 3. 文件名中包含空格的问题 在用shell过程中,经常会遇到处理文件名中包含空格的问题 对此,参考Linux shell脚本遍历带空格的文件名,尝试了用tr将ls输出结果替换为问 号,的确是可以的: CLi@PC-CLI-1 ~/develop/docbook/books/arm_vs_mips/src $ ls arm_vs_mips.xml arm_vs_mips_____xml - Copy_bak glossary.xml Makefile remove_bak.sh arm_vs_mips.xml.bak ch01_reduced_instruction_set.xml images reference.xml remove_bak.sh.bak CLi@PC-CLI-1 ~/develop/docbook/books/arm_vs_mips/src $ ls | tr " " "\?" arm_vs_mips.xml arm_vs_mips.xml.bak arm_vs_mips_____xml?-?Copy_bak ch01_reduced_instruction_set.xml glossary.xml images Makefile reference.xml remove_bak.sh remove_bak.sh.bak [提 cygwin中的tr在shell中工作不正常? -> 实际上是cygwin中的显示有问题 示] 不过,另外提及一下,目前遇到一个问题,就是上述的代码: ls | tr " " "\?" 放到shell中执行: local sub_folders=`ls $input_folder | tr "\32" "\?"`; echo '444 sub_folders='$sub_folders; 当时结果是tr无效,输出的效果中文件名中的空格没有被替换为问号。 其中当前环境是用的Cygwin,tr版本为: CLi@PC-CLI-1 ~/develop/docbook/books/arm_vs_mips/src $ tr --version tr (GNU coreutils) 8.15 Packaged by Cygwin (8.15-1) Copyright (C) 2012 Free Software Foundation, Inc. License GPLv3+: GNU GPL version 3 or later . This is free software: you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law. Written by Jim Meyering. 后来终于经过一番折腾,而搞清楚了: 把问号换成其他的,比如<,>等: local sub_folders=`ls $input_folder | tr "\32" "\<"`; local sub_folders=`ls $input_folder | tr "\32" "\>"`; 也都是可以看到替换的结果的。 并且也可以用: each_item=`echo $each_item | tr "\<" " "`; each_item=`echo $each_item | tr "\>" " "`; 再替换回来的。 而对于上述的问号替换空格,虽然没有显示出来,但是如果没有此操作的话,后面 for each_item in $sub_folders; do 所得到的每个item中, arm_vs_mips.xml - Copy_bak 就会变成三个字符串: arm_vs_mips.xml - Copy_bak 而有此操作,后面得到的就是一个独立的字符串: arm_vs_mips.xml - Copy_bak 所以明白了根本原因是,Cygwin中,没有正确的显示出来,实际上,是已经替换成功的了 。 不过很悲催的是,单独echo问号字符,却又是可以正常显示的。。。 说实话,这样的bug,真的很让人崩溃。。。太浪费时间了。。。 2.7.2. Linux Shell参考资料 1. Linux Shell Scripting Tutorial - A Beginner's handbook 用经典的那句中文介绍此书就是,对于Linux Shell的"从入门到精通",^_^ 专门提及一下常用的供参考的章节: □ test command or [ expr ] 2.8. Windows Batch File 2.8.1. Windows Batch File简介 2.8.2. Windows Batch File学习心得 2.8.3. Windows Batch File参考资料 1. 第 3 章 上层语言 目录 3.1. 上层语言综述 3.2. C#学习心得 3.3. C++ 3.3.1. C++学习笔记 3.4. 为何高级语言不能直接操作硬件? 摘要 3.1. 上层语言综述 3.2. C#学习心得 关于C#的学习心得,已移至这里:C#学习心得 3.3. C++ 3.3.1. C++学习笔记 学习C++过程中,遇到的一些内容,觉得有必要记录下来,以供后用。 其中主要是之前用C语言,所以接触C++,有些内容不太习惯,因此记录C++中和C不同的, 需要注意的部分内容。 1. protected,public,private 对应的含义,用下表,可以很容易区分: 表 3.1. protected,public,private之间的区别   关键字   Private 私有 Protected 受保护 Public 公有 友元函数 友元函数 友元函数 对应作用(允许谁访问) 该类自己的函数 该类自己的函数 该类自己的函数   子类的函数 子类的函数     该类的对象 2. 函数带默认值的参数 可以在调用函数的时候,不给那些带默认值的参数赋值,即调用函数时候,参数少了 几个。 不过要注意的是,带默认值的参数,肯定都是从最右边的一个或几个。 3. 枚举变量的引用 类名::某一枚举变量值 而不是C语言中直接引用:某一枚举变量值 4. 用new生成的变量与直接定义变量的区别 知道new要和delete配对使用。 直接定义变量:函数中的局部变量的话,在栈stack中分配,静态分配,函数调用完, 自动释放内存,即编译器自己帮你释放内存,不需要你关心。 全局的话,应该和C语言中的没区别,就是普通全局变量,始终占用内容,会增加程序 耦合度,在可以的情况下,应尽量少用。 用new生成的变量:动态分配,在堆heap中分配,所以要自己关心内存的使用,在不用 此变量的时候,用delete释放内存,否则就产生了内存泄露,即有部分不再使用的变 量存在于内存中,属于站着茅坑不拉屎的类型。 一般常见用法一直就是在类的构造函数中用new分配内存给某个变量,然后对应地在析 构函数中用delete释放对应变量所占的内存。 5. 重载Overload 同一个函数名,参数的个数和类型不同。 6. 关于继承inherit 没啥多说的,只是自己不太熟悉,导致看到某个类B调用某个函数func1,结果在B类的 定义中找不到,最后才发现原来是B类继承A类,A类中有public的函数func1,因此才 有B可以调用func1。 3.4. 为何高级语言不能直接操作硬件? TODO:整理为什么说汇编语言可以直接操作硬件-CSDN论坛-CSDN.NET-中国最大的IT技术社 区到这里。 第 4 章 网络相关的语言 目录 4.1. XML 4.1.1. XML相关的参考资料 4.2. HTML 4.2.1. HTMl学习心得 4.2.2. HTML相关的参考资料 摘要 此处记录一些和网络相关的一些语言,比如HTML,XML等 4.1. XML 此处记录一些关于XML的学习心得和一些有价值的参考资料。 4.1.1. XML相关的参考资料 1. XML标准概览 目前已有的和XML相关的一些标准的概览,可参考: a. XML 标准概览: 第 1 部分 b. XML 标准概览: 第 4 部分 4.2. HTML 此处记录一些关于HTML的学习心得,以及一些有价值的参考资料。 4.2.1. HTMl学习心得 1. HTML页面功能不正常,应该首先去检查对应的HTML源代码是否正常 在折腾【记录】折腾给WordPress Google XML Sitemap中添加支持子目录自动扫描功 能,包含HTML静态页面等可识别的格式的过程中,发现一个问题: 当(混了和php和javascript的)HTML页面中,某功能不正常,结果调试了很长时间, 最终发现,原来是某段用于生成HTML代码的javascript代码,不小心多写了个双引号 ,导致生成的HTML代码不正常,功能因此也就不正常了。 但是在此过程中,没有任何的提示,因此也就不知道是此处错了,所以,最大的感慨 是,对于HTML页面来说,如果功能上不正常的话,那么第一时间应该去看看与此相关 的HTML代码是否正确。. 2. 4.2.2. HTML相关的参考资料 1. HTML实体定义,特殊字符等资料 特殊字符方面,已有有人整理出来,把字符都显示出来,并且分门别类列出来了,很 不错。 下面列出几个值得推荐的: □ HTML特殊字符大全 特点:中文的,分类很全 □ HTML Special Characters 特点:英文的,也分类了 2. HTML的颜色和对应的名字 □ HTML Color Chart with 140 Color Names 特点:关于HTML中的颜色和对应的名字,这个页面很简洁直观 □ HTML Color Names 特点:英文。这个页面的内容,非常全,更加不错 3. Unicode字符集 □ Unicode Table 特点:关于Unicode字符集的相关字符的表格,几乎包括了所有字符。 □ Unicode Lookup 特点:可以找到每个Unicode的各种进制的值之外,还有对应的HTML的entity 4. BIG5 a. BIG5码表 ☆ Big5 (Traditional Chinese) character code table 特点:单一页面,包含了所有的字符,方便查找。 ☆ Big 5 Code Table 特点:多个页面,不是很方便查找。但是带有颜色区分,便于分辨各种类型 的字符。 b. 简体中文和繁体中文之间的转换 简繁转换 参考书目 Word VBA [1] 【整理】word vba学习记录 [2] 菜鸟谈VBA最最基础入门《原创》 [3] Word VBA 教程:Microsoft Word Visual Basic 参考 [4] Word VBA内置的Help [5] 【解决】word VBA中,获取当前所选内容的标题序号/标题数字/heading level/ heading number 其他 [6] BlogsToWordPress 的用法的举例说明