chr(0)代表什么?InStr(string, chr(0))代表什么意思? chr(0)代表什么?InStr(string, chr(0))代表什么意思?还有经常在vb中出现$,干什么用的? 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 返回 String,其中包含有与指定的字符代码相关的字符 。语法Chr(charcode)必要的 charcode 参数是一个用来识别某字符的 Long。说明0 到 31 之间的数字与标准的非打印 ASCII 代码相同。例如,Chr(10) 可以返回换行字符。charcode 的正常范围为 0 – 255。然而,在 DBCS 系统,charcode 的实际范围为 -32768 到 65535。注意 ChrB 函数作用于包含在 String 中的字节数据。ChrB 总是返回一个单字节,而不是返回一个字符,一个字符可能是一个或两个字节。ChrW 函数返回包含 Unicode 的 String,若在不支持 Unicode 的平台上,则其功能与 Chr 函数相同。 返回 Variant (Long),指定一字符串在另一字符串中最先出现的位置。语法 InStr([start, ]string1, string2[, compare])InStr 函数的语法具有下面的参数:部分 说明 start 可选参数。为数值表达式,设置每次搜索的起点。如果省略,将从第一个字符的位置开始。如果 start 包含 Null,将发生错误。如果指定了 compare 参数,则一定要有 start 参数。 string1 必要参数。接受搜索的字符串表达式。 string2 必要参数。被搜索的字符串表达式。 Compare 可选参数。指定字符串比较。如果 compare 是 Null,将发生错误。如果省略 compare,Option Compare 的设置将决定比较的类型。 设置 compare 参数设置为:常数 值 描述 vbUseCompareOption -1 使用Option Compare 语句设置执行一个比较。 vbBinaryCompare 0 执行一个二进制比较。 vbTextCompare 1 执行一个按照原文的比较。 vbDatabaseCompare 2 仅适用于Microsoft Access,执行一个基于数据库中信息的比较。 返回值如果 InStr返回 string1 为零长度 0 string1 为 Null Null string2 为零长度 Start string2 为 Null Null string2 找不到 0 在 string1 中找到string2 找到的位置 start > string2 0 说明InStrB 函数作用于包含在字符串中的字节数据。所以 InStrB 返回的是字节位置,而不是字符位置。 chr(0)是ASCII码为0的字符,InStr(string, chr(0))是判断string里是否存在ASCII码为0的字符另外,给你一个建议:学VB一定要先学会查MSDN chr(0)是不可见的字符,instr(string,chr(0))是返回string中chr(0)从左边计算的位置(字符数) chr(0)是个不可见字符,我不知道它代表什么意思?如下面一个函数: 判断是否为光驱?Private Sub Form_Load() Dim nType As Long, S As String, sDrive As String Dim pos As Integer S = String(256, Chr(0)) GetLogicalDriveStrings Len(S), S Do pos = InStr(S, Chr(0)) sDrive = Left(S, pos - 1) If Len(sDrive) = 0 Then Exit Do S = Mid(S, pos + 1) nType = GetDriveType(sDrive) List1.AddItem Left(sDrive, 2) & " = " & GetDriveName(nType) Loop Until pos <= 0End Sub中用到了两个chr(0),为什么使用它? chr(0)就是ASCII值为0的字符在c中就是"\0",也就是字符串结束标志S = String(256, Chr(0))这是为S分配256个空间,并且用chr(0)填充,实际上用其它字符也可以。如果不分配空间调用GetLogicalDriveStrings会出错pos = InStr(S, Chr(0))sDrive = Left(S, pos - 1)调用GetLogicalDriveStrings后结果储存在S中,是以\0结尾的字符串。这里就是将\0之前的部分取出来 $表示字符串类型Dim a$则a$是string类型而不是Variant 如何激活CAD窗口。 SQL问题 字符串的计数 在记事本中我使用了一个MDI窗体,并用DIM NewDoc AS NEW FORM1定义了子窗口 求主从表处理的例子 请教如何循环读取listview里的数据,谢谢!!! 如何进行控件的循环?? 怎样实现实时记录的存储, 一个关于filelistbox控件的问题 方法‘~’作用于对象‘~’失败???(VB+SQL) 大哥我不懂,这个函数如何调用!! 有两个问题请教各位帮助解决,谢谢!
start 可选参数。为数值表达式,设置每次搜索的起点。如果省略,将从第一个字符的位置开始。如果 start 包含 Null,将发生错误。如果指定了 compare 参数,则一定要有 start 参数。
string1 必要参数。接受搜索的字符串表达式。
string2 必要参数。被搜索的字符串表达式。
Compare 可选参数。指定字符串比较。如果 compare 是 Null,将发生错误。如果省略 compare,Option Compare 的设置将决定比较的类型。
设置 compare 参数设置为:常数 值 描述
vbUseCompareOption -1 使用Option Compare 语句设置执行一个比较。
vbBinaryCompare 0 执行一个二进制比较。
vbTextCompare 1 执行一个按照原文的比较。
vbDatabaseCompare 2 仅适用于Microsoft Access,执行一个基于数据库中信息的比较。
返回值如果 InStr返回
string1 为零长度 0
string1 为 Null Null
string2 为零长度 Start
string2 为 Null Null
string2 找不到 0
在 string1 中找到string2 找到的位置
start > string2 0
说明InStrB 函数作用于包含在字符串中的字节数据。所以 InStrB 返回的是字节位置,而不是字符位置。
InStr(string, chr(0))是判断string里是否存在ASCII码为0的字符另外,给你一个建议:学VB一定要先学会查MSDN
如下面一个函数: 判断是否为光驱?
Private Sub Form_Load()
Dim nType As Long, S As String, sDrive As String
Dim pos As Integer
S = String(256, Chr(0))
GetLogicalDriveStrings Len(S), S
Do
pos = InStr(S, Chr(0))
sDrive = Left(S, pos - 1)
If Len(sDrive) = 0 Then Exit Do
S = Mid(S, pos + 1)
nType = GetDriveType(sDrive)
List1.AddItem Left(sDrive, 2) & " = " & GetDriveName(nType)
Loop Until pos <= 0End Sub中用到了两个chr(0),为什么使用它?
在c中就是"\0",也就是字符串结束标志S = String(256, Chr(0))
这是为S分配256个空间,并且用chr(0)填充,实际上用其它字符也可以。如果不分配空间调用GetLogicalDriveStrings会出错pos = InStr(S, Chr(0))
sDrive = Left(S, pos - 1)
调用GetLogicalDriveStrings后结果储存在S中,是以\0结尾的字符串。这里就是将\0之前的部分取出来
Dim a$
则a$是string类型而不是Variant