Can’t edit CSV because it has too many columns. How to search and replace list of strings in CSV?

Tanquen

Board Regular
Joined
Dec 14, 2017
Messages
81
Office Version
  1. 365
Platform
  1. Windows
I have a large odd CSV export that has too many columns to open without error. I need to replace about a thousand strings in the file. I ran a crude macro that extracted all the strings I need to find and replace. So I not have a one column listing the old strings and a new column listing the new strings.

What is the best way to search and replace all the strings in the original file? There are two instances of each string in the file and the original CSV must remain unchanged in any other way. I know Excel like to add commas for empty cells and such.

Other than manually doing hundreds of search and replace actions in notepad or something is there a cool VBA way to open the CSV as a text file and parse through it and then save it?
Thanks.
 

Excel Facts

What did Pito Salas invent?
Pito Salas, working for Lotus, popularized what would become to be pivot tables. It was released as Lotus Improv in 1989.
Can't you do it with notepad or Word? Notepad can do "replace all".
 
Upvote 0
Yes. :)

"Other than manually doing hundreds of search and replace actions in notepad or something"

But.

There are over 500 unique strings that I would need to search for. That is why I was also asking about using a list. Like I have a list of 500 strings to search for in another file. I’ve seen some examples but they add lines to the file or they check one row and then move on. This CSV has hundreds of unique strings in a row.
 
Upvote 0
Open the csv file in Word and follow the example below.

Code:
Sub Macro2()

    With Selection.Find
        .Text = "word"
        .Replacement.Text = "wordword"
        .Forward = True
        .Wrap = wdFindContinue
        .Format = False
    End With
    Selection.Find.Execute Replace:=wdReplaceAll
    
        With Selection.Find
        .Text = "office"
        .Replacement.Text = "officeoffice"
        .Forward = True
        .Wrap = wdFindContinue
        .Format = False
    End With
    Selection.Find.Execute Replace:=wdReplaceAll

End Sub
 
Upvote 0
Solution
I'll have an array of 500+ strings but this test works. It's very slow with just the two test strings though.

Code:
Sub Macro2()


    Dim ArrayOLD(1 To 2) As String
    Dim ArrayNEW(1 To 2) As String
    
    ArrayOLD(1) = "SPWT_SLC504.SLC504.N17:52"
    ArrayOLD(2) = "SPWT_SLC504.SLC504.N17:152"
    
    ArrayNEW(1) = "{[Process_PLC]B3[0].1}"
    ArrayNEW(2) = "[Process_PLC]B3[10].1]"


    For i = 1 To UBound(ArrayOLD)
       
        With Selection.Find
            .Text = ArrayOLD(i)
            .Replacement.Text = ArrayNEW(i)
            .Forward = True
            .Wrap = wdFindContinue
            .Format = False
        End With
        Selection.Find.Execute Replace:=wdReplaceAll
        
    Next i


End Sub
 
Upvote 0

Forum statistics

Threads
1,225,750
Messages
6,186,805
Members
453,373
Latest member
Ereha

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