?
Solved

Randomize a Replace Problem…

Posted on 2006-07-16
3
Medium Priority
?
168 Views
Last Modified: 2013-12-24
I have a few paragraphs of text.  I’m trying to replace the text “keyword” with a few things.  Ideally I’m doing…

<cfset text = “This is a sentence about keyword and keyword is really a keyword of this sentence about keyword.”>
<cfset newtext = ReReplaceNoCase(text, "keyword", " <strong>keyword</strong> ", "all")>
<cfoutput>#newtext#</cfoutput>

However, I would like to randomize this.  I don’t want every instance of “keyword” replaced with <strong>keyword</strong>.  I want to alternate the replacements between…

<strong>keyword</strong>
<u>keyword</u>
<a href=”…”>keyword</a>
<font color=”red”>keyword</font>

How might I go about doing this??

Thanks for the pointers!
0
Comment
Question by:rebies
  • 2
3 Comments
 
LVL 1

Author Comment

by:rebies
ID: 17119621
One thought I just had, can I put a function inside of the ReReplaceNoCase??

---
<cffunction name="RandReplace">
      <cfargument name="tobereplaced" type="string" required="Yes">
      
      <cfif **randomnumber** EQ 1>
            <cfreturn "<strong>#tobereplaced#</strong>">
      <cfelse>
            <cfreturn "<u>#tobereplaced#</u>">
      </cfif>
</cffunction>

<cfset newtext = ReReplaceNoCase(text, "keyword", RandReplace(“keyword”), "all")>
---
0
 
LVL 13

Accepted Solution

by:
usachrisk1983 earned 2000 total points
ID: 17122316
That function wont work, since as soon as it returns a string, that'll be the string that Replace uses for each keyword, so it'll be random as to wether or not the keyword will be replaced, but not specific instances of the keyword.  Here is a function I put together for you to try:

<cffunction name="randomReplacement" output="true" returntype="string">
 <cfargument name="inputString" type="string" required="yes">
 <cfargument name="oldKeyword" type="string" required="yes">
 <cfargument name="newKeyword" type="string" required="yes">

 <cfset placeHolderNew = '**_NEW_**'>
 <cfset placeHolderOld = '**_OLD_**'>
 <cfset listDelims = ' ,.!?'>
 
 <cfset newString = inputString>

 <cfset findOldKeyword = 1>
 <cfloop condition="findOldKeyword gt 0">
  <cfset findOldKeyword = ListFindNoCase(newString, oldKeyword, listDelims)>
  <cfif findOldKeyword gt 0>
   <cfif RandRange(1,2) is 1>
    <cfset newString = ListSetAt(newString, findOldKeyword, placeHolderNew, listDelims)>  
   <cfelse>
    <cfset newString = ListSetAt(newString, findOldKeyword, placeHolderOld, listDelims)>  
   </cfif>
  </cfif>
 </cfloop>  
 
 <cfset newString = ReplaceNoCase(newString, placeHolderNew, newKeyword, 'ALL')>
 <cfset newString = ReplaceNoCase(newString, placeHolderOld, oldKeyword, 'ALL')>
 
 <cfreturn newString>
   
</cffunction>

I tested it like so:

<cfloop index="i" from="1" to="30">
 <cfinvoke method="randomReplacement" inputString="My dog is brown, is your dog, sir?" oldKeyword="dog" newkeyword="cat" returnvariable="testing">
 <cfoutput>#testing#</cfoutput><br>
</cfloop>

And do get 30 seemlingly random results :)

If you can think of other things that could be attached to a keyword besides the listDelims I included, just tag them on to that list.
0
 
LVL 1

Author Comment

by:rebies
ID: 17218974
Sorry usachrisk1983, I forgot I left this question open.  Yes, your solution did help me out.  Thanks!

Andrew
0

Featured Post

Get expert help—faster!

Need expert help—fast? Use the Help Bell for personalized assistance getting answers to your important questions.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction This article explores the design of a cache system that can improve the performance of a web site or web application.  The assumption is that the web site has many more “read” operations than “write” operations (this is commonly the ca…
The following information will get you familiar with your new DV server, including the (mt) Account Center, the Plesk Control Panel, our world-renowned support department and the rest of the (mt) tools that come with your new service.
The Relationships Diagram is a good way to get an overall view of what a database is keeping track of. It is also where relationships are defined. A relationship specifies how two tables connect to each other. As you build tables in Microsoft Ac…
SQL Database Recovery Software repairs the MDF & NDF Files, corrupted due to hardware related issues or software related errors. Provides preview of recovered database objects and allows saving in either MSSQL, CSV, HTML or XLS format. Ensures recov…
Suggested Courses

607 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