RegEx Help...

Juggler_IN

Active Member
Joined
Nov 19, 2014
Messages
358
Office Version
  1. 2003 or older
Platform
  1. Windows
I want help with the attached function ... It takes a textual string specified by the argument x and converts every field masked with \ to its Unicode code unless it is already Unicode or masked with \. The code replaces the first match of the regular expression from the end of the string to the beginning of the string. The rest of the string remains unchanged. For example,
— RegExChr("\a\b\c\1\2\3") outputs “\a\b\c\1\2\u0033\.”
— RegExChr("\a\b\c\1\2\u0033\") outputs “\a\b\c\1\u0032\u0033\.”
— RegExChr("\a\b\c\1\u0032\u0033\") outputs “\a\b\c\u0031\u0032\u0033\.”

But, if I add the chr "\" ... is not getting converted to its Unicode value. That is,

?RegExChr("\a\b\c\1\2\3\\") gives \a\b\c\1\2\3\ but what I want is \a\b\c\1\2\3\u005C\.

?RegExChr("\a\b\c\1\2\3\u005C\") gives the expected \a\b\c\1\2\u0033\u005C\.

I tried removing Replace(RegExChr, "\\", "\") but still do not the output desired.

Any thoughts?
VBA Code:
Function RegExChr(ByVal x As String) As String

    Dim oRegex As Object, i As Double, oCarry As Object

    If oRegex Is Nothing Then
        Set oRegex = CreateObject("vbScript.RegExp")
        oRegex.Global = True
        oRegex.Pattern = "(?:\\(\\)|\\u[0-9A-F]{4}|\\(?!\\)(.))"
    End If

    RegExChr = x

    Set oCarry = oRegex.Execute(x)

    For i = oCarry.Count - 1 To 0 Step -1
        If oCarry(i).SubMatches(1) <> Empty Then
            RegExChr = RegExHlp(oCarry(i), RegExChr, RegExAsc(oCarry(i).SubMatches(1)) & "\")
            RegExChr = Replace(RegExChr, "\\", "\")
            Exit Function
        ElseIf oCarry(i).SubMatches(0) = "\" Then
            RegExChr = RegExHlp(oCarry(i), RegExChr, "\")
            RegExChr = Replace(RegExChr, "\\", "\")
            Exit Function
        End If
    Next i

End Function
Function RegExHlp(ByRef Match As Object, ByVal s As String, ByVal r As String) As String

    RegExHlp = Left(s, Match.FirstIndex) & r & Mid(s, Match.FirstIndex + Match.Length + 1)

End Function
Function RegExAsc(ByVal s As String) As String

    If AscW(s) > 256& * 256& - 1 Then
    Else
        RegExAsc = "\u" & String(4 - Len(Hex(AscW(s))), "0") & Hex(AscW(s))
    End If

End Function
 

Excel Facts

How to fill five years of quarters?
Type 1Q-2023 in a cell. Grab the fill handle and drag down or right. After 4Q-2023, Excel will jump to 1Q-2024. Dash can be any character.
Try replace Function RegExChr with below and see how it goes.
Code:
Function RegExChr(ByVal x As String) As String

    Dim oRegex As Object, i As Double, oCarry As Object

    If oRegex Is Nothing Then
        Set oRegex = CreateObject("vbScript.RegExp")
        oRegex.Global = True
        oRegex.Pattern = "\\u[0-9A-F]{4}|\\(.)"
    End If

    RegExChr = x

    Set oCarry = oRegex.Execute(x)

    For i = oCarry.Count - 1 To 0 Step -1
        If oCarry(i).submatches(0) <> Empty Then
            RegExChr = RegExHlp(oCarry(i), RegExChr, RegExAsc(oCarry(i).submatches(0)) & "\")
            RegExChr = Replace(RegExChr, "\\", "\")
            Exit Function
        End If
    Next i

End Function
 
Upvote 0
@Fuji; This works but partly ... ?RegExChr("\\\a\b\c\\\1\2\3\\") gives \\a\b\c\\1\2\3\u005C\ ... should be \\\a\b\c\\\1\2\3\u005C\.
 
Upvote 0
I think I get what you wanted to do.
This one is capable to deal with multiple strings.
Code:
Function RegExChr(ByVal s As String)
    Dim x, mtch As Object, m As Object, i&, ref, d
    With CreateObject("VBScript.RegExp")
        .Global = True
        .Pattern = "(\\(.+?)(?=(\\|$)))"
        Set mtch = .Execute(s)
        For i = mtch.Count - 1 To 0 Step -1
            If mtch(i).submatches(1) Like "[!u]*" Then
                Set m = mtch(i)
                ref = RegExAsc(m.submatches(1))
                RegExChr = Application.Replace(s, m.firstindex + 1, m.Length, ref)
                If RegExChr Like "*[!\]" Then RegExChr = RegExChr & "\"
                Exit For
            End If
        Next
    End With
End Function

Function RegExAsc(ByVal s As String) As String
    Dim i&, t$
    For i = 1 To Len(s)
        t = Mid$(s, i, 1)
        If AscW(t) <= 256& * 256& - 1 Then
            RegExAsc = RegExAsc & "\u" & String(4 - Len(Hex(AscW(t))), "0") & Hex(AscW(t))
        End If
    Next
End Function
HEX.xlsm
ABCDE
1SourceShould beResult
2\a\b\c\1\2\3\a\b\c\1\2\u0033\TRUE\a\b\c\1\2\u0033\
3\a\b\c\1\2\u0033\\a\b\c\1\u0032\u0033\TRUE\a\b\c\1\u0032\u0033\
4\a\b\c\1\u0032\u0033\\a\b\c\u0031\u0032\u0033\TRUE\a\b\c\u0031\u0032\u0033\
5\a\b\c\1\2\3\\\a\b\c\1\2\3\u005C\TRUE\a\b\c\1\2\3\u005C\
6\a\b\c\1\2\3\u005C\\a\b\c\1\2\u0033\u005C\TRUE\a\b\c\1\2\u0033\u005C\
7\\\a\b\c\\\1\2\3\\\\\a\b\c\\\1\2\3\u005C\TRUE\\\a\b\c\\\1\2\3\u005C\
8\\\a\b\c\\\10\20\30\\\\a\b\c\\\10\20\u0033\u0030\
Sheet1
Cell Formulas
RangeFormula
C2:C7C2=B2=E2
E2:E8E2=RegExChr(A2)
 
Upvote 0
Solution

Forum statistics

Threads
1,225,738
Messages
6,186,725
Members
453,368
Latest member
positivemind

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top