Solved

regular expression in VBScript

Posted on 2002-03-04
16
370 Views
Last Modified: 2008-02-01
Hi,

I have a string with some links in there
for example: str1 = " this is link1, link2 and link3"

I can use regular expression to find the links then make the Matches Object. Then use
  For Each strMatch In strMatches
    'with strMatch.Value and strMatch.Index
    'to replace link1 to alink1, link2 to alink2,
    'and link3 to alink3.
  Next
The problem is if link1=link2 then at the end I will have aalink1, aalink2, and alink3.  (notice double a's)
That is because, the first replace replaces link1 to alink1, then the second replace (for link2) will replace link1 in alink1 to alink1 -> then result is aalink1.

Does anyone know how to fix that problem?

Thanks in advance.


0
Comment
Question by:phuctran
  • 5
  • 5
  • 2
  • +3
16 Comments
 
LVL 33

Expert Comment

by:knightEknight
ID: 6840051
a quick fix would be to run another expression after the first one that replaces "aalink" with "alink"
0
 
LVL 33

Expert Comment

by:knightEknight
ID: 6840054
or, in the first expression, instead of scanning for "link" , scan for " link"  ( \slink )
0
 
LVL 18

Expert Comment

by:mgfranz
ID: 6840188
Don't do this with For Each, loop through the string one time only.  This might be different from what you are looking for, but you get the idea;

<%
sString = "this is link1, link2 and link3"
Response.Write "Search string:" &sString

Set RegX = NEW RegExp
SearchPattern = "link"
RegX.Pattern = SearchPattern
RegX.Global = True
ReplacedText = RegX.Replace(sString, "a"&RegX.Pattern)

Response.Write "<p>New String: "&ReplacedText
%>
0
 
LVL 3

Author Comment

by:phuctran
ID: 6840748
Sorry, I am not clear on my question.

The word is not "link".

for example:

this is www.yahoo.com, www.excite.com, and www.yahoo.com

I want to create http links for that string, so when I display it on browsers, I can click on that to go to the site.
0
 
LVL 3

Author Comment

by:phuctran
ID: 6840755
just like this page, after I type www.yahoo.com then submit, there is a link for that.
0
 
LVL 75

Expert Comment

by:Anthony Perkins
ID: 6840901
mgfranz,

<off topic>
http://devx.experts-exchange.com/jsp/qShow.jsp?ta=asp&qid=20192557
</off topic>

Anthony
0
 
LVL 3

Expert Comment

by:pbryan
ID: 6841109
try this function
----------------------
<%
Function replacelinks(textin)
Dim intLinkStartPos
Dim intLinkEndPos
Dim textout
Dim intLinkLenInc
Dim strLink
intLinkStartPos = InStr(textin, "http:")
If intLinkStartPos = 0 Then intLinkStartPos = InStr(textin, "https:")
If intLinkStartPos = 0 Then
    intLinkStartPos = InStr(textin, "www.")
Else
    If InStr(textin, "www.") <> 0 Then
        If intLinkStartPos>InStr(textin, "www.") Then
            intLinkStartPos = InStr(textin, "www.")
        End If
    End If
End If
While intLinkStartPos > 0
   
    intLinkEndPos = InStr(intLinkStartPos, textin, " ")
    If intLinkEndPos < intLinkStartPos Then
        intLinkEndPos = Len(textin) + 1
    End If
    strLink = Mid(textin, intLinkStartPos, intLinkEndPos - intLinkStartPos)
    If InStr(strLink, ",") > 0 Then
        strLink = Left(strLink, InStr(strLink, ",") - 1) & Mid(strLink, InStr(strLink, ",") + 1)
    End If
    intLinkLenInc = 16 + Len(strLink)
    If Left(Mid(textin, intLinkStartPos, intLinkEndPos - intLinkStartPos), 4) = "http" Then
        textin = Left(textin, intLinkStartPos - 1) & " <a href=" & Chr(34) & strLink & Chr(34) & ">" & Mid(textin, intLinkStartPos, intLinkEndPos - intLinkStartPos) & "</a>" & Mid(textin, intLinkEndPos )
    Else
        intLinkLenInc = intLinkLenInc + 7
        textin = Left(textin, intLinkStartPos - 1) & " <a href=" & Chr(34) & "http://" & strLink & Chr(34) & "> " & Mid(textin, intLinkStartPos, intLinkEndPos - intLinkStartPos) & "</a>" & Mid(textin, intLinkEndPos )
    End If
     
         
    intLinkStartPos = InStr(intLinkEndPos + intLinkLenInc, textin, "http:")
    If intLinkStartPos = 0 Then intLinkStartPos = InStr(intLinkEndPos + intLinkLenInc,textin, "https:")
    If intLinkStartPos = 0 Then
        intLinkStartPos = InStr(intLinkEndPos + intLinkLenInc, textin, "www.")
    Else
        If InStr(intLinkEndPos + intLinkLenInc, textin, "www.") <> 0 Then
            If intLinkStartPos > InStr(intLinkEndPos + intLinkLenInc, textin, "www.") Then
                intLinkStartPos = InStr(intLinkEndPos + intLinkLenInc, textin, "www.")
            End If
        End If
    End If
Wend
replacelinks = textin
end function
%>
0
 
LVL 3

Expert Comment

by:pbryan
ID: 6841113
you use the function like this

<%=replacelinks("this is www.yahoo.com, www.excite.com,  and www.yahoo.com")%>

or

<%=replacelinks("this is http://www.yahoo.com, www.excite.com, and https://www.mysecuresite.com")%>

0
IT, Stop Being Called Into Every Meeting

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

 
LVL 9

Expert Comment

by:AlfaNoMore
ID: 6841160
Don't be daft, a Regular expression is the only way to do this, and this is why:

http://aspemporium.com/aspEmporium/src/vbs_srcview.asp?source=regexp_LinkURLs.asp

You'll see how easy it is!!! ;-)
0
 
LVL 18

Accepted Solution

by:
mgfranz earned 200 total points
ID: 6841678
Wow, thats a lot of code pbryan.

A simple RegExp is all you need, the following takes a parsed input, check to see if the letters "www" or anything following ://, and creates a "link" out of it;

sString = Server.HTMLEncode(rs.Fields("Notes"))

Set RegX = NEW RegExp
SearchPattern = "(((\w+):\/\/|www)([^\s]+\w))" RegX.Pattern = SearchPattern
RegX.Global = True
a = "$1"
b = "$2"
c = "http://$1"
ReplaceString = "<a href='"&Trim(c)&"'>"&Trim(a)&"</a>"

ReplacedText = RegX.Replace(sString, ReplaceString)
ReplacedText = Replace(ReplacedText, "http://http://", "http://", VBTextCompare)

Response.Write ReplacedText
%>

Wrap it in a Function.
0
 
LVL 18

Expert Comment

by:mgfranz
ID: 6841680
You can delete the "b" match.
0
 
LVL 3

Author Comment

by:phuctran
ID: 6842159
AlfaNoMore,

Please find a 200-points question "points for AlfaNoMore" and accept that so I can give you the credit.

Thank you.
0
 
LVL 18

Expert Comment

by:mgfranz
ID: 6842823
Diid you not mean to accept my comment as an answer?  If not, just send a message to Community Support to ask for a change.
0
 
LVL 3

Author Comment

by:phuctran
ID: 6843079
mgfranz,

I accept yours and AlfaNoMore's.

However, the pattern is not used for all cases.  For example, if you have

s = "this is http://www.yahoo.com and <img src='http://www.yahoo.com/images/thisimage.gif'>"  then the http://... in src="" will be changed to <a href=""> also.

The link AlfaNoMore gave me have the same problem.

I will work on that case.  You gave me the right direction (using $1, $2); therefore, the points are yours.

Thank you.

0
 
LVL 18

Expert Comment

by:mgfranz
ID: 6843093
Ahh, I see... A simple edit to the RegExp would solve this.  I'm sure you can kludge it up.
0
 
LVL 3

Author Comment

by:phuctran
ID: 6843117
0

Featured Post

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

I have helped a lot of people on EE with their coding sources and have enjoyed near about every minute of it. Sometimes it can get a little tedious but it is always a challenge and the one thing that I always say is:  The Exchange of information …
This demonstration started out as a follow up to some recently posted questions on the subject of logging in: http://www.experts-exchange.com/Programming/Languages/Scripting/JavaScript/Q_28634665.html and http://www.experts-exchange.com/Programming/…
It is a freely distributed piece of software for such tasks as photo retouching, image composition and image authoring. It works on many operating systems, in many languages.
Access reports are powerful and flexible. Learn how to create a query and then a grouped report using the wizard. Modify the report design after the wizard is done to make it look better. There will be another video to explain how to put the final p…

747 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

13 Experts available now in Live!

Get 1:1 Help Now