4800计算器ce是什么意思显示Done什么意思

各种计算机语言简介和总结
各种计算机语言简介和总结
本文主要介绍了各种计算机语言的分类和关系,以及记录了笔者对其中部分语言,如Word VBA,Excel VBA,Python,C++,Javascript,C#等,的心得和体会。
本文提供多种格式供:
HTML版本的在线地址为:
有任何意见,建议,提交bug等,都欢迎去讨论组发帖讨论:
完成此文逻辑框架
添加如何在Windows下的cmd环境下使用Python脚本
添加了C++的内容
添加了Javascript的内容
添加了Word VBA的内容
添加了Excel VBA的内容
添加了Python的内容
添加了C#的内容
添加了Python的crifanLib.py的全部内容
添加了C#的crifanLib.cs的全部内容
添加了Python的BeautifulSoup心得
已将Python移出至单独的book
已将C#移出至单独的book
添加为何高级语言不能直接操作硬件
本文章遵从:
第 1 章 各种计算机语言简介
1.1. 各种计算机语言简介
第 2 章 脚本语言
2.1. 脚本语言综述
脚本语言综述
2.2. 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文档中,并且输出的时候,要将该值根据某些约定,再分成几个部分等等,这类的操作,手动实现,要一个个去找对应的表格,然后找到对应的值,然后手动复制,粘贴,一点点做,效率很低,而如果可以用宏实现,只需要写好宏代码,运行一下,即可省去大量的精力。
不过,就像说的:"VBA功能很强大,但并不是万能的,也并不是所有工作都需要用VBA来解决,也并不是所有工作用VBA来解决都会很简单,这要根据实际情况而定,有些工作你用VBA来解决的话相反会变得很麻烦。"
2.3.2. Word VBA的一些基本概念
此处介绍一下,Word VBA中的一些基本单位(名词):story, section, paragrah, line, character,table,cell,row, column
对于所选一段文字后,即引用Selection,其中会包含很多属性,Selection.XXX 其中XXX就有下面列出来的很多种,现在简单说说我对这些属性含义的理解:
Story中文直译为 故事,经过测试,感觉对于word文档来说,好像就是整个文档的内容。
Text不必多解释,就是所选的内容
Sections节。经测试,好像整个word文档,就一个节,有点像story,具体两者的区别,暂未搞懂。
Paragraphs段落。按照中文的段落的含义理解,怎么说也应该有个几十行之类的文字,才算一个段落的,这是之前学语文的时候的感觉。结果发现这里的段落和中文意思的段落,差别很大,一个文档里面,没多少行字,结果段落就几百个了,貌似是一个单词,一个换行,一个表格中的值,都算一个段落。
Sentences句子,同常理,不多解释。
Words单词,同常理,不多解释。
Characters字符,同常理,不多解释。
Tables,Cells,Rows,Columns表格,同常理。其中包含了很多个cell,即单元格。每个cell,都对应不同的行和列。
(打印)输出所选Range中(其包含很多个表格)中的第二个表格中的第三行第四列的值,表示为:
Print Selection.Tables(2).Cell(3, 4)
其中第三行第四列,不是Cell(2,3),因为其单元格的下表是从1开始,而不是原以为的类似于C语言或者Excel中的0为起始值的。
End ,Start即Selection.Start和Selection.End ,都是直接赋值的
所以,如果你想要选中某段内容(文字),那么只要找到你所要的起点和终点,然后将其值赋值给Selection.Start和Selection.End,即可选中该段内容(文字)。
当然,也可以利用两者算出所选内容的长度:
slection_len
= Selection.End - Selection.Start
2.3.3. Word vba学习记录
获得所选range的文字尝试了一下,发现两种都可以:
Selection.Text
Selection.Range.Text
不等于符号VBA里面的不等于号,用"&&"表示,而不是其他C等语言里面的"!="
&&,即大于号和小于号的组合,意思也很明确,既不大于也不小于,所以就是不等于了。
如何选中一行并获得对应的文字 和 wdMove和wdExtend的区别前提,光标(或叫插入点)已经移动到该行了,但是想要选中该行,并想要获得对应所选Range的文字
此时可以用如下代码:
Selection.MoveDown Unit:=wdLine, Count:=1, Extend:=wdExtend
wdLine是单位(Unit)
类似的Unit还有:wdParagraph,wdWindow,wdScreen。
和WdExtend对应的还有wdMode
对此,VBA教程的解释是:“如果是 wdMove,则所选内容折叠到结束位置,并向下移动。如果是 wdExtend,则所选内容向下扩展。默认值为 wdMove。”
没完全理解,但是经过测试得知,如果是mdMove,那就是光标移动到对应位置了,但是没有选择这(光标移动的)起点到终点,此处为整个这一行,的内容,如果是wdExtend,那就是不仅移动光标了,并且同时选中了起点到终点的内容。
如何跳转到某一标题 和 如何移动光标/插入点
Selection.GoTo What:=wdGoToHeading, Which:=wdGoToAbsolute, Count:=5
这里主要是利用Goto语句
wdGoToHeading说明掉转的单位是heading标题
wdGoToAbsolute表示是绝对位置的跳转
于此相对应的还有wdGoToFirst, wdGoToLast, wdGoToNext, wdGoToPrevious, wdGoToRelative。
更多详细内容,请参考
另外,对于移动光标/插入点,可以借鉴如下做法:
本示例将所选内容移至当前文字部分的开头。如果所选内容位于文档正文部分,则本示例将所选内容移至文档的开头
Selection.HomeKey Unit:=wdStory, Extend:=wdMove
wdStory属于wdUnits
其他类似的还有wdColumn,wdLine,wdRow等
如何获得选中的标题的序号前提,已经选择某一标题了,想要获得该标题前面的序号
比如对这个标题:
PAPRBY / RubyVerifoneDefaults
想要获得标题的序号,即2.1
可通过下列代码获得当前标题的序号,即2.1
Selection.Bookmarks("\headinglevel").Range.ListFormat.ListString
\headinglevel是VBA里面的预定义标签
关于此内容的详细解释,请参考:
如何返回函数的返回值关于这点,网上找,没几个说的很清楚的,最后还是通过VBA的Help才搞懂如何返回函数返回值的。
此处,简单解释如下:
一个Function函数的语法为:
[Public | Private | Friend] [Static] Function name [(arglist)] [As type]
[statements]
[name = expression]
[Exit Function]
[statements]
[name = expression]
End Function
name即为函数名
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 Function
看懂后,多说一句,有问题,还是先找VBA的Help系统,比百度,google等,有时候更准确,方便,易懂。
函数内部任何地方都可以出现[name = expression]
字符串处理函数关于VBA中的字符串相关的函数,刚发现,office 2010 中的 VBA的help文件里面,有已经总结好的了:
上述字符串处理相关的函数,多数都是见名知意,容易看懂和使用, 但是也有些不太容易搞懂,或者和普通C语言等里面的字符串处理函数不同的,需要额外说明的,解释如下:
Space, String其中Space很方便,比如想要输出10个空格,当然你可以通过自己手动的写成"
",但是有了space,用其更方便,直接写成
即代表了10个空格。同理
String(number,characterToRepeate)
用于输出多个某一字符,而对于前面的空格来说,也可以用string表示,即
Space(10)=String(10, 32)
其中32=0x20,是space的ASCII值。而String的优点在于,也可以输出其他字符,包括0x0~0x1F之类不可见字符。
InStr, InStrRev这个InStr,其实就是C语言的strstr
InStr([start, ]string1, string2[, compare])
意思为:"返回 Variant (Long),指定一字符串在另一字符串中最先出现的位置。"
而InStrRev意思和InStr类似,只不过是"从字符串的末尾算起"。
举例说明:
posOfPoint = InStr("abc.def", ".") ’ 查找"abc.def"中的".",返回值为4
Asc, ChrAsc是将字符转换为ASCII数值,Chr是将数值转换为ASCII字符。
MyNumber = Asc("A")
' 返回 65。
MyChar = Chr(97)
' 返回 a。
如何创建文件和输出信息到文件里面在VBA中创建(log)文件的两种方法.
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
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
' 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
如何获得当前文件的文件名 和 当前文件所在路径
获得当前文件所在的路径:ActiveDocument.Path。注意:所得结果,最后没有那个路径分隔符"\"
获得当前文件的文件名:ActiveDocument.Name
获得当前文件的路径和文件名,即全名:ActiveDocument.FullName
VB里面的一些常量office 2010的help文件里面已有总结:
Visual Basic 常数Visual Basic for Applications 定义了一些常数,使程序设计变得更为简单。下列常数可在程序代码中的任何地方代替实际值:
Calendar 常数
CallType 常数
Color 常数
Compiler 常数
Dir、GetAttr 和 SetAttr 常数
IMEStatus 常数
Instr、StrComp 常数
Keycode 常数
Miscellaneous 常数
MsgBox 常数
QueryClose 常数
QueryClose 常数
Shell 常数
StrConv 常数
系统颜色常数
VarType 常数
Visual Basic 常数
其中,此处打算把一些我所常用到的一些常数列出来,以供参考
Miscellaneous 常数下列常数由 Visual Basic for Applications 中的类型库定义,可用来在代码中的任何地方代替实际值
2.3.4. 授人鱼不如授人以渔
下面介绍一些更多有用的参考资料,以及介绍一下遇到问题如何去解决问题。
通过VBA内置的Help系统查询不懂的内容在word里面打开VBA编辑器编辑vba代码后,对于常见的一些对象,属性,方法(函数)等的具体解释,多数都可以通过选择该对象/属性/方法,然后按F1键,打开帮助,其会自动跳转到对应的帮助内容,很是方便,而且很多的细节,解释的也比较详细,可以多多利用。
其中都包括了一些基本知识的详细解释,比如上面提到的,关于VBA中关于Function的返回值,其要去查看Help文件,就可以通过选择某函数,
比如,选中:
Function funcName()
End Function
中的Function,然后按F1键,系统自动会跳转到Help文件中关于Function的解释,很方便。
常见函数分类列表office 2010中VBA的help文件做的很好,里面总结了一些常见的函数,前面列出来的,就是那个字符串处理相关的函数。
下面列出了,其他一些类别,先放到这里,以备后查:
网上在线查找相关帮助内容刚找到的,微软的官方的在线帮助:
2.4. Excel VBA
看此部分内容之前,关于VBA的基础知识,以及word VBA的相关知识,可参考
2.4.1. Excel VBA中基本的名词和概念
此处介绍一些Excel中的最基本的概念,搞清楚这些概念,是继续深入学习Excel的基础。
Excel中,我们已经知道的是,从概念上来说,从大到小是:
Excel文件 => Excel文件中页表sheet => sheet中的行和列 => 行列交叉点所对应的单元格
这些名词和概念,对应到Excel VBA中就是:
Workbook => Worksheet => Column, Row => Cell
并且,每个概念,都对应着一个该单词的复数形式,表示的是对应的一组的该单位,
如:Workbooks表示一组,很多个当前已经打开的Excel文件等。
下面稍微详细地介绍一下各自的含义和用法。
Workbookworkbook属于workbooks,workbooks是当前打开的所有的workbook的集合(总称)。
对于想要获得单个的workbook,有这些方式:
Workbooks.Item(N)
Workbooks(N)
Workbooks("excel_file_name.xlsx")
Workbook所具有的一些常见函数有:
Workbook.Open
Workbook.Add
Workbook.Save
Workbook.SaveAs
对于其更多的函数和属性,细心的人,自然会想到利用前面提到的自学方法,去更加详细的学习了解的。以后对此类提示,就不再多提醒了。
Worksheetworksheet即我们常说的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")
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
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是对应的列的名字。
对于行的操作,也是同样适用的。
即可以先去对某行去命名,然后就可以通过对该名字来引用到该行了。
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中的一些基本操作
如何添加注释VBA中的注释,是以单引号"'"开头的,其后内容,都视为注释内容。
另外一种,也可以通过关键字REM或Rem加上个空格,之后的内容,也会被识别为注释。
REM this is a excel maro
' this is a excel maro
如何调试简单的说,有两种方式:
Msgbox一是直接调用Msgbox去弹出对话框打印信息。
MsgBox "Currently opening Excel file is: " & ActiveWorkbook.Name
其中,字符串链接/拼接,用&符号。
log文件二是新建一个log文件,将调试或打印信息输出到log文件中去。
关于如何创建文件,可参考:
获得当前的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
一些通用的属性和方法(函数)对于选中当前的内容,比如workbook,sheet等,可以通过.Select来选中,
Sheets("sheet_name").Select
对于当前的内容的名字,对应的是.Name属性,比如:
Sheets("sheet_name").Name
很多内容,都有move的功能,详细用法请自己探索。
新增一个新的内容,比如workbook,sheet等,都可以用Add方法。
2.4.3. Excel VBA更多的学习资料
VBA for Microsoft Office Excel 2007关于Excel VBA的一些基础知识,可以去看这里:
Excel 2007 VBA参考大全关于Excel VBA,这本书介绍的很全:
电驴地址:
2.4.4. 授人鱼不如授人以渔
此部分内容,其实在之前中,已有提到,此处再次强调一下。
在学习VBA(和任何类似知识)的过程中,学会利用系统已有资源。
即,在VBA中,可以供我们利用的资源,至少有这些:
VBA中的对象浏览器(Object Browser)可以通过在写VBA代码的过程中,对于任何你不太懂,想要了解更多细节的内容,选中该内容,比如我想要了解workbook,那就选中workbook,然后右键=>Object Browser,即可在Object Browser中查找到你所要的内容,其中可以直观快速地看到对应目标所具有的变量成员和函数等,很是方便。
内置的Help选中想要查询的内容,然后按F1,VBA即可调用Help帮助系统,可以查询到更多的细节和实例用法。
例如,我知道了workbook是对应于当前Excel文件,想要了解workbook有哪些属性和方法,
那么可以去F1的Help中输入workbook,然后搜索到很多条目,其中第一条就是:
“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
这样的话,你就可以可以通过自学的方式,去搞懂很多内容了。
通过录制宏去照葫芦画瓢如果还是不会操作,那么可以去通过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
所以,如果你想要实现类似的操作,至少是复制粘贴等动作,就可以参考上述代码了。
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学习记录
&script&中没有指定脚本语言类型网上介绍:
script的语法,说是script中type是必须的,即必须要写成:
&script type="XXX"&
但是实际上看到一些网页,比如:
的html源代码中,script没有指定type:
//*****there is some function。
function checkMail(s) {
var pattern=/w+@w+.[a-z]+/;
if(pattern.test(s)) {
一直很奇怪,为何可以用。
后来终于找到解释了:
二.指定脚本语言的方式:
1.指定整个文档默认的脚本语言。
&META http-equiv="Content-Script-Type" content="type"&
content:指定脚本语言的类型如:"text/tcl", "text/javascript", "text/vbscript".
由于文档默认的脚本类型是JavaScript,因此我们在使用JavaScript时最简单且兼容性最好的方式为&script&&/script&
不过,即使如此,还是没在上面那个网页的html源码中,看到有期望的:
&META http-equiv="Content-Script-Type" content="type"&
估计是该网页的javascript写的不够严谨吧。
关于字符串的format函数参考这里:
举例用法:
return "&a href=’{1}’ target=’_blank’ class=’ucard’ pid=’{0}’&{2}&/a&".format(portraitId, cmturl, cmtname);
其中,{0},{1}.{2}分别代表format后面的参数的第一个,第二个,第三个。
打印或枚举出一个变量的所有属性property,或一个字典的所有键(key)和值(value)
打印或枚举出一个变量(对象)的所有的属性property参考这里:
知道了,可以这样写:
for(var name in someObject){
document.write(name + "=" + someObject[name])
此处someObject是某个对象变量,然后上面的for语句,加上"变量[属性]"的方式,可以获得所有的变量,并打印出来。
打印或枚举出一个字典的所有键key和值value参考这里:
后经过测试,下面代码在IE9里面可以运行:
var arrayData = {
for (__key in arrayData)
document.write( __key + "=" + arrayData[__key])
其中上面的arrayData是一个字典,然后也是通过"字典[键]"的方式,获得对应键的值
如果某一行javascript脚本出错,则执行结果出错,但是却没有任何提示最新在折腾的过程中,发现一个现象:
html或php页面中,出现了非所预料的结果,知道是代码某处写错了,但是不值得是哪个文件的哪一行错了。
最后才无意间发现,原来是某个js脚本中,之前添加的多余的注释TODO字符串,没有及时删除,导致页面结果出错。
由于感慨,js代码执行结果异常,某行出错了,也没有任何的提示和警告,导致最终结果虽然错了,也知道是代码问题,但是却无法定位错误的位置。
如此去调试html,php,javascript混合的页面,真的很痛苦。
期待高手可以指教指教,有没有更加有效的调试方法。
如果改动了javascript中的内容,一定要刷新页面,才可以看到最新改动的效果!!!最新在折腾的过程中,在修改对应的javascript文件sitemap.js,但是,始终却不见修改后的效果。
但是很奇怪的是,之前对于HTML页面等内容,修改了后,点击对应选项,是可以看到最新的改动的效果的。
而此处不论如何改动js文件,结果都不见效果。
最后,才发现,原来对于js文件,需要重新刷新HTMl页面,其会重新加载最新的js文件,然后才能看到最新的效果。
而之前不知道这一点,真的是浪费了非常非常多的时间。
2.6.1. PHP学习记录
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."/";
例 2.1. addTailSlash使用范例
//add tail slash
$homePath = $this-&addTailSlash($homePath);
//echo "homePath=".$homePath."&br /&";
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);
2.6.2.1.3. 检查一个字符串是否在另一个数组中:strExistInArr
//eg: check txt is in array("txt", "html", "pdf")
function strExistInArr($str, $arr)
if($arr[0] == "*")
$found = T
$found = F
$arrLen = count($arr);
for($i=0; $i&$arrL $i++)
//if(0 == strcmp($str, $arr[$i]))
if($str == $arr[$i])
$found = T
例 2.2. strExistInArr使用范例
$fileValid = $this-&strExistInArr($fileSuf, $validSuf);
2.6.2.1.4. 从文件过滤类型生成文件后缀列表:genValidSuffix
//eg: from "*.*." to array("html", "txt")
function genValidSuffix($fileType)
$validSuf = array();
$splitedArr = explode(";", $fileType);
$arrSize = count($splitedArr);
//echo "splited arrary size=".$arrSize."&br /&";
for($i=0; $i&$arrS $i++)
$singleSufDef = $splitedArr[$i];
//echo "singleSufDef=".$singleSufDef."&br /&";
if($singleSufDef && ($singleSufDef != ""))
//echo "singleSufDef not null &br /&";
$suffix = str_replace("*.", "", $singleSufDef);
//echo "suffix=".$suffix."&br /&";
if($suffix == "*")
//echo "found & suffix &br /&";
$validSuf = array("*");
//echo "add $suffix into array &br /&";
array_push($validSuf, $suffix);
return $validS
例 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"]);
例 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";
echo "filename=". $filename";
closedir($dirHandler);
2.7. Linux Shell
2.7.1. Linux Shell学习心得
递归函数中的变量值被下层调用所修改的问题由于Linux shell中默认定义的变量都是全局的,所以导致在递归函数中定义的变量,在下一层调用中修改了值后,返回上一层,改变量已被修改,导致运行结果不对。
解决办法就是,给相应的变量加上local前缀,表示是局部变量,即可。
详情参看:
./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
解决办法:自己去找错误的位置,是不是也是由于类似的,使用某个功能的时候,传递的参数,超过该功能所期望的参数的个数了。如果超过了,估计多数情况下,也都是你自己使用不当,或者没有进行合适的处理而导致的。
文件名中包含空格的问题在用shell过程中,经常会遇到处理文件名中包含空格的问题
对此,参考,尝试了用tr将ls输出结果替换为问号,的确是可以的:
CLi@PC-CLI-1 ~/develop/docbook/books/arm_vs_mips/src
arm_vs_mips.xml
arm_vs_mips_____xml - Copy_bak
glossary.xml
remove_bak.sh
arm_vs_mips.xml.bak
ch01_reduced_instruction_set.xml
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
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_
当时结果是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 &http://gnu.org/licenses/gpl.html&.
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_ do
所得到的每个item中,
arm_vs_mips.xml - Copy_bak
就会变成三个字符串:
arm_vs_mips.xml
而有此操作,后面得到的就是一个独立的字符串:
arm_vs_mips.xml - Copy_bak
所以明白了根本原因是,Cygwin中,没有正确的显示出来,实际上,是已经替换成功的了。
不过很悲催的是,单独echo问号字符,却又是可以正常显示的。。。
说实话,这样的bug,真的很让人崩溃。。。太浪费时间了。。。
2.7.2. Linux Shell参考资料
用经典的那句中文介绍此书就是,对于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#学习心得
关于C#的学习心得,已移至这里:
3.3.1. C++学习笔记
学习C++过程中,遇到的一些内容,觉得有必要记录下来,以供后用。
其中主要是之前用C语言,所以接触C++,有些内容不太习惯,因此记录C++中和C不同的,需要注意的部分内容。
protected,public,private对应的含义,用下表,可以很容易区分:
表 3.1. protected,public,private之间的区别
Private 私有
Protected 受保护
Public 公有
对应作用(允许谁访问)
该类自己的函数
该类自己的函数
该类自己的函数
子类的函数
子类的函数
该类的对象
函数 带默认值的参数可以在调用函数的时候,不给那些带默认值的参数赋值,即调用函数时候,参数少了几个。
不过要注意的是,带默认值的参数,肯定都是从最右边的一个或几个。
枚举变量的引用类名::某一枚举变量值
而不是C语言中直接引用:某一枚举变量值
用new生成的变量与直接定义变量的区别知道new要和delete配对使用。
直接定义变量:函数中的局部变量的话,在栈stack中分配,静态分配,函数调用完,自动释放内存,即编译器自己帮你释放内存,不需要你关心。
全局的话,应该和C语言中的没区别,就是普通全局变量,始终占用内容,会增加程序耦合度,在可以的情况下,应尽量少用。
用new生成的变量:动态分配,在堆heap中分配,所以要自己关心内存的使用,在不用此变量的时候,用delete释放内存,否则就产生了内存泄露,即有部分不再使用的变量存在于内存中,属于站着茅坑不拉屎的类型。
一般常见用法一直就是在类的构造函数中用new分配内存给某个变量,然后对应地在析构函数中用delete释放对应变量所占的内存。
重载Overload同一个函数名,参数的个数和类型不同。
关于继承inherit没啥多说的,只是自己不太熟悉,导致看到某个类B调用某个函数func1,结果在B类的定义中找不到,最后才发现原来是B类继承A类,A类中有public的函数func1,因此才有B可以调用func1。
3.4. 为何高级语言不能直接操作硬件?
TODO:整理到这里。
第 4 章 网络相关的语言
此处记录一些和网络相关的一些语言,比如HTML,XML等
此处记录一些关于XML的学习心得和一些有价值的参考资料。
4.1.1. XML相关的参考资料
XML标准概览目前已有的和XML相关的一些标准的概览,可参考:
此处记录一些关于HTML的学习心得,以及一些有价值的参考资料。
4.2.1. HTMl学习心得
HTML页面功能不正常,应该首先去检查对应的HTML源代码是否正常在折腾的过程中,发现一个问题:
当(混了和php和javascript的)HTML页面中,某功能不正常,结果调试了很长时间,最终发现,原来是某段用于生成HTML代码的javascript代码,不小心多写了个双引号,导致生成的HTML代码不正常,功能因此也就不正常了。
但是在此过程中,没有任何的提示,因此也就不知道是此处错了,所以,最大的感慨是,对于HTML页面来说,如果功能上不正常的话,那么第一时间应该去看看与此相关的HTML代码是否正确。.
4.2.2. HTML相关的参考资料
HTML实体定义,特殊字符等资料特殊字符方面,已有有人整理出来,把字符都显示出来,并且分门别类列出来了,很不错。
下面列出几个值得推荐的:
特点:中文的,分类很全
特点:英文的,也分类了
HTML的颜色和对应的名字
特点:关于HTML中的颜色和对应的名字,这个页面很简洁直观
特点:英文。这个页面的内容,非常全,更加不错
Unicode字符集
特点:关于Unicode字符集的相关字符的表格,几乎包括了所有字符。
特点:可以找到每个Unicode的各种进制的值之外,还有对应的HTML的entity
特点:单一页面,包含了所有的字符,方便查找。
特点:多个页面,不是很方便查找。但是带有颜色区分,便于分辨各种类型的字符。
简体中文和繁体中文之间的转换
Word VBA内置的Help

我要回帖

更多关于 卡西欧4800计算器 的文章

 

随机推荐