Foxtable(狐表)用户栏目专家坐堂 → [求助]从一个字符串中提取特定字符的问题


  共有14659人关注过本帖树形打印复制链接

主题:[求助]从一个字符串中提取特定字符的问题

帅哥哟,离线,有人找我吗?
dlovef
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:幼狐 帖子:172 积分:1323 威望:0 精华:0 注册:2011/6/6 12:22:00
[求助]从一个字符串中提取特定字符的问题  发帖心情 Post By:2011/8/9 11:13:00 [只看该作者]

有没有什么办法能够从诸如"一二三四五AAA00000六七八"这样的字符串中将“AAA00000”提取出来。
1,“AAA00000”格式固定,三位字母,五位数字
2,“AAA00000”出现位置不固定


 回到顶部
帅哥哟,离线,有人找我吗?
yanzhen2010
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:童狐 帖子:212 积分:1564 威望:0 精华:0 注册:2011/7/20 21:00:00
  发帖心情 Post By:2011/8/9 11:31:00 [只看该作者]

以下是引用dlovef在2011-8-9 11:13:00的发言:
有没有什么办法能够从诸如"一二三四五AAA00000六七八"这样的字符串中将“AAA00000”提取出来。
1,“AAA00000”格式固定,三位字母,五位数字
2,“AAA00000”出现位置不固定

,“AAA00000”后边的字符个数固定吗?


 回到顶部
帅哥哟,离线,有人找我吗?
狐狸爸爸
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2011/8/9 11:43:00 [只看该作者]

Dim s As String  = "一二三四五AAA00000六七八"
Dim i1 As Integer
Dim i2 As Integer
For i As Integer = 0 To s.Length -3
    If s(i) = s(i+1) AndAlso s(i) = s(i+2) Then
        i1 = i
        Exit For
    End If
Next
For i As Integer = 0 To s.Length -5
    If s(i) = s(i+1) AndAlso s(i) = s(i+2) AndAlso s(i) = s(i+3) AndAlso s(i) = s(i+4) Then
        i2 = i
        Exit For
    End If
Next
If i2 > i1 Then
   messagebox.show(s.SubString(i1,8))
End If
[此贴子已经被作者于2011-8-9 11:47:20编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
狐狸爸爸
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2011/8/9 11:46:00 [只看该作者]

可以看看.net的正则表达式,会更简单点。

 回到顶部
帅哥哟,离线,有人找我吗?
dlovef
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:幼狐 帖子:172 积分:1323 威望:0 精华:0 注册:2011/6/6 12:22:00
  发帖心情 Post By:2011/8/9 11:48:00 [只看该作者]

回复yanzhen2010:后面的字数也不固定。
回复狐狸爸爸:"AAA00000"只是个样式,AAA代表任意三位字母,00000代表任意五位数字。所以您的这段代码好像行不通吧。

 回到顶部
帅哥哟,离线,有人找我吗?
狐狸爸爸
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2011/8/9 11:50:00 [只看该作者]

这样简单点:

 

Dim s As String  = "一二三四五AAA00000六七八"
For i As Integer = 0 To s.Length -3
    If s(i) = s(i+1) AndAlso s(i) = s(i+2) Then
        If s(i+3) = s(i+4) AndAlso s(i+3) = s(i+5) AndAlso s(i+3) = s(i+6) AndAlso s(i+3) = s(i+7) Then
           messagebox.show(s.SubString(i,8))
            Exit For
        End If
    End If
Next


 回到顶部
帅哥哟,离线,有人找我吗?
dlovef
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:幼狐 帖子:172 积分:1323 威望:0 精华:0 注册:2011/6/6 12:22:00
  发帖心情 Post By:2011/8/9 12:21:00 [只看该作者]

回复狐狸爸爸:"AAA00000"只是个样式,AAA代表任意三位字母,00000代表任意五位数字。所以您的这段代码好像行不通吧。


 回到顶部
帅哥哟,离线,有人找我吗?
狐狸爸爸
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2011/8/9 12:27:00 [只看该作者]

Dim s As String  = "一二三四五AAA00000六七八"
For i As Integer = 0 To s.Length - 8
    If Char.IsLetter(s(i)) AndAlso  s(i) = s(i+1) AndAlso s(i) = s(i+2) Then
        If Char.IsDigit(s(i+3)) AndAlso  s(i+3) = s(i+4) AndAlso s(i+3) = s(i+5) AndAlso s(i+3) = s(i+6) AndAlso s(i+3) = s(i+7) Then
           messagebox.show(s.SubString(i,8))
            Exit For
        End If
    End If
Next

 回到顶部
帅哥哟,离线,有人找我吗?
xongyijd
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:童狐 帖子:245 积分:3629 威望:0 精华:1 注册:2010/5/9 18:45:00
  发帖心情 Post By:2011/8/9 12:29:00 [只看该作者]

以下是引用狐狸爸爸在2011-8-9 11:50:00的发言:

这样简单点:

 

Dim s As String  = "一二三四五AAA00000六七八"
For i As Integer = 0 To s.Length -3
    If s(i) = s(i+1) AndAlso s(i) = s(i+2) Then
        If s(i+3) = s(i+4) AndAlso s(i+3) = s(i+5) AndAlso s(i+3) = s(i+6) AndAlso s(i+3) = s(i+7)
Then
           messagebox.show(s.SubString(i,8))
            Exit For
        End If
    End If
Next

弄糊涂了,狐狸爸爸能不能用解释含义


 回到顶部
帅哥哟,离线,有人找我吗?
dlovef
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:幼狐 帖子:172 积分:1323 威望:0 精华:0 注册:2011/6/6 12:22:00
  发帖心情 Post By:2011/8/9 13:02:00 [只看该作者]

狐爸,以下代码执行后结果是这样的?请问是什么原因?
Dim s As String = "一二三四五AAA00000六七八"
Dim str As String
For i As Integer = 1 To s.Length-8
str = Mid(s,i,8)
If Char.IsLetter(Left(str,3)) And Char.IsNumber(Right(str,5)) Then
Output.Show(str)
End If
Next

结果

图片点击可在新窗口打开查看此主题相关图片如下:截图05.jpg
图片点击可在新窗口打开查看


 回到顶部
总数 23 1 2 3 下一页