田草博客

互联网田草博客


网友交流QQ群:11740834 需注明申请加入原因

微信 公众号:ByCAD

邮箱:tiancao1001x126.com
ByCAD,微信公众号
首页 | 普通 | 电脑 | AutoCAD | VB/VB.NET | FLash | 结构 | 建筑 | 电影 | BIM | 规范 | 软件 | ID
-随机-|-分布-
-博客论坛-|-﨣﨤﨧﨨-
-网站导航-|-规范下载-
-BelovedFLash欣赏-

用户登陆
用户:
密码:
 

站点日历
73 2024 - 12 48
1234567
891011121314
15161718192021
22232425262728
293031


站点统计

最新评论



第80奥斯卡颁奖落幕 固定网页背景图片
未知 VB 返回字符串中两个关键字中间字符   [ 日期:2008-02-27 ]   [ 来自:本站原创 ]  HTML
VB 返回字符串中两个关键字中间字符


上次再写VB分析网页源代码中的URL的时候就用到,比如分析源代码中间所有url,url的格式是<a href="#">XXX</a>,url就在<a 和</a>中间,怎么得到呢。

考虑到普遍性,可以写一个function

'在字符串中查找位于关键字key1和关键字key2之间的字符串
'S 待分析的字符串
'Key1 关键字1
'Key2 关键字2 (key1不能和key2相同)
'L 关键字key1和关键字key2之间字符串的最大可能长度 但不能超过 Len(S)-Len(Key1)-Len(key2)的长度
'New_Str() 关键字key1和key2之间的字符串数组
Function GetStrInStrByKey(S As String, Key1 As String, Key2 As String, L As Long, ByRef New_Str() As String) As Integer
    On Error GoTo E:
    Dim i As Long
    i = Len(S)
    If i = 0 Or i < Len(Key1) + Len(Key2) Then
        GetStrInStrByKey = 0
        Exit Function
    End If
    Dim N As Integer
    Dim index() As Long
    N = inStr_n(S, Key1, index) ' 总共有N个关键字key1
    Dim Temp As String
    Dim Temp1 As Long
    Dim M As Integer
    For i = 0 To N - 1
        Temp = Mid(S, index(i) + Len(Key1), L) '从第一个关键字key1开始,向后面数L长度的字符 (新得到的字符串前面去掉关键字key1)
        ReDim Preserve New_Str(M) '数组元素增加一个
        Temp1 = InStr(Temp, Key2)
        If Temp1 <> 0 Then
            New_Str(M) = Left(Temp, Temp1 - 1)
        End If
        M = M + 1
    Next
    GetStrInStrByKey = 1
    Exit Function
E:
    Debug.Print Err.Description
    GetStrInStrByKey = 0
End Function


[本日志由 田草 于 2008-03-01 09:13 PM 编辑]


暂时没有评论
发表评论 - 不要忘了输入验证码哦!
作者: 用户:  密码:   注册? 验证:  防止恶意留言请输入问题答案:2*3=?  
评论:

禁止表情
禁止UBB
禁止图片
识别链接
识别关键字

字体样式 文字大小 文字颜色
插入粗体文本 插入斜体文本 插入下划线
左对齐 居中对齐 右对齐
插入超级链接 插入邮件地址 插入图像
插入 Flash 插入代码 插入引用
插入列表 插入音频文件 插入视频文件
插入缩进符合
点击下载按钮 下标 上标
水平线 简介分割标记
表  情
 
Tiancao Blog All Rights Reserved 田草博客 版权所有
Copyright ©