4

我有下面的代码。如何在括号内获取字符串?谢谢你。

Dim tmpStr() As String
    Dim strSplit() As String
    Dim strReal As String
    Dim i As Integer

    strWord = "hello (string1) there how (string2) are you?"

    strSplit = Split(strWord, "(")
    strReal = strSplit(LBound(strSplit))

    For i = 1 To UBound(strSplit)
        tmpStr = Split(strSplit(i), ")")
        strReal = strReal & tmpStr(UBound(tmpStr))
    Next
4

4 回答 4

3
Dim src As String = "hello (string1) there how (string2) are you?"
Dim strs As New List(Of String)

Dim start As Integer = 0
Dim [end] As Integer = 0

While start < src.Length

    start = src.IndexOf("("c, start)
    If start <> -1 Then
        [end] = src.IndexOf(")"c, start)
        If [end] <> -1 Then
            Dim subStr As String = src.Substring(start + 1, [end] - start - 1)
            If Not subStr.StartsWith("(") Then strs.Add(src.Substring(start + 1, [end] - start - 1))
        End If
    Else
        Exit While
    End If

    start += 1 ' Increment start to skip to next (

End While

这应该这样做。

Dim result = Regex.Matches(src, "\(([^()]*)\)").Cast(Of Match)().Select(Function(x) x.Groups(1))

也会工作。

于 2012-07-27T10:20:32.477 回答
3

这就是正则表达式的用途。学习他们,爱他们:

' Imports System.Text.RegularExpressions
Dim matches = Regex.Matches(input, "\(([^)]*)\)").Cast(of Match)()
Dim result = matches.Select(Function (x) x.Groups(1))

两行代码而不是十多行。

用 Stephan Lavavej 的话来说:“即使是复杂的正则表达式也比等效的代码更容易理解和修改。”</p>

于 2012-07-27T10:32:13.983 回答
1
  1. 使用String.IndexOf获取第一个左括号 ( x ) 的位置。

  2. 再次使用 IndexOf 获取第一个右括号(y)的位置。

  3. 使用String.Substring根据xy的位置获取文本。

  4. 删除字符串的开头直到y +1。

  5. 根据需要循环

那应该让你继续前进。

于 2012-07-27T10:27:40.947 回答
0

这也可能有效:

Dim myString As String = "Hello (FooBar) World"
Dim finalString As String = myString.Substring(myString.IndexOf("("), (myString.LastIndexOf(")") - myString.IndexOf("(")) + 1)

还有2行。

于 2012-07-27T10:26:46.663 回答