• 0

[VB.NET] Deleting string from text file


Question

9 answers to this question

Recommended Posts

  • 0
  Puggsley said:
I need to search through a .txt file and remove a specific string. Anything i've found so far deletes a specific line number, but the string could appear on any line.

Ok, this answer will work, but I'm sure there are less expensive ways to achive the desired result. That said... Load the entire file into a string (oh my!) and then do a String.Replace("OLD VALUE", "") and then save the string to the file.

If the file is small, this is not a big deal, if the file is large it can take a serious chunk of memory.

If I think of something else I'll post back.

  • 0

Thanks for the prompt reply!

Thats the best solution i could come up with as well. As for the file size, there is about 10 files, varying from 20kb to 5mb so it could be a problem. Time and memory isn't too much of an issue and if it becomes one then it is something to look at in the future, but right now its more important to get something working

How much of a problem do you think it will be?

  • 0

I think the 5mb file is a LITTLE bit of an issue, but since these days (as opposed to 1995) memory is cheap and plentiful it's not something I would freak about.

If you write your code well, when you find a better solution, you'll be able to change that small chunk of code and get better performance. (hack? oh a little)

If it was me, and I was out of time, I'd go with the original idea and then at a later date do the performance gain. I've done tech work for 20 years and dev for 15. *I* find it most important to get the job done, over having it done well. Done well is nice, but not if it's NOT done. (read that sentence carefully)

  • 0

Would it be possible to read the file just one line at a time? This way only one line will have to be in memory. There may be a way to loop this method until the end of file has been reached. Just search through each line one at a time for the string to remove it. After the line has been analyzed, unload it and load the next line.

I'm not sure how you would go about coding this, but perhaps the idea will spark something. :)

  • 0

The problem with the "line by line" is that VB opens access to the file and will allocate a chunk of memory near the size of the file in either case. This is a concern and I'm sure there is a better solution that I have stated above... at the moment I don't have one. (sorry)

EDIT:

I thought I'd make a comment here: Besides the coding issues another point of development work is to know which goals to reach for... I had a friend back in San Francisco that spent a month creating a reporting engine in VB. Considering his fee and the abilities of VB the time would have been much better spent purchasing Crystal Reports or some other engine and having a large number of reports created by the end of that first month. (of course there are arguments for creating the engine, but in this case it was a serious waste of the client's cash)

SOMETIMES getting something done quickly vs writing tight, memory and CPU light code is better. It's a case by case issue based on the information at hand and the time alotted.

Just food for thought.

Peace,

James Rose

New York City

Edited by jameswjrose
  • 0

OK, so i took the plunge and went with the original suggestion but am having real difficulties getting it to work

To make sure its nothing else in the program i created a new project and put the following code on the form load event and created a text file with the contents "Hello World" in the output folder

Dim FileContents as String
Dim objReader as System.IO.StreamReader
objReader - New StreamReader(Environment.CurrentDirectory & "\test.txt")
FileContents = objReader.ReadToEnd
objReader.Close
FileContents.Replace("Hello", "")
Dim objWriter as System.IO.StreamWriter
objWriter = New StreamWriter(Environment.CurrentDirectory & "\test.txt")
objWriter.Write(FileContents)
objWriter.Close

From watching in explorer the program seems to zero byte the file and then write exactly the same contents back again.

Any ideas would be greatly appreciated!

This topic is now closed to further replies.
  • Recently Browsing   0 members

    • No registered users viewing this page.
  • Posts

    • good grief .... first brittney murphy in the first run now him
    • I do not think that Windows 11 will pick up pace as October 2025 draws near. Even though I was a Windows Vista fan back in the day, this really reminds me of the (lack of) transition between Windows XP to Windows Vista. In the end, Microsoft had to backtrack and extend Windows XP support until Windows 7 was adopted.
    • How many minutes until they rename this? Outside of the search engine itself, it seems anything with the Bing name attached quickly gets renamed.
    • Save 15% on the Insta360 Link 2 4K Webcam, now available at the lowest price by Taras Buria Insta360 is known for its high-quality 360-cameras, but the company also offers high-end webcams for those who want to elevate their video calls or streaming. Right now, the Insta360 Link 2 4K webcam is available at a new all-time low price, saving you 15% off the standard MSRP. The Insta360 Link 2 is not your standard 4K webcam. This camera is mounted on a two-axis gimbal that physically pans and tilts to follow you as you move around the room. You can also set boundaries to prevent the camera from capturing certain areas and control it with gestures for a hands-free experience. The camera itself has a large 1/2" 4K sensor that captures more light and details with HDR and low-light mode support. A larger sensor also means a more natural bokeh effect. Built-in microphones support voice focus and voice suppression, and the camera can balance your voice with background music. Other features include additional modes, such as whiteboard mode, DeskView mode, portrait mode, and privacy mode. The latter tilts the camera down after 10 seconds of inactivity (you can also push it down manually). The Insta360 Link 2 is also remotely operated with a dedicated phone app, plus its desktop software lets you adjust features like background, filters, and more. Insta360 Link 2 4K Webcam - $169.99 | 15% off on Amazon US Insta360 Link 2 4K Webcam Tripod Bundle - $195 | 15% off on Amazon US This Amazon deal is US-specific and not available in other regions unless specified. If you don't like it or want to look at more options, check out the Amazon US deals page here. Get Prime (SNAP), Prime Video, Audible Plus or Kindle / Music Unlimited. Free for 30 days. As an Amazon Associate, we earn from qualifying purchases.
    • RIP Jonathan Joss aka John Redcorn https://www.nbcnews.com/news/us-news/jonathan-joss-king-hill-voice-actor-killed-san-antonio-shooting-rcna210437
  • Recent Achievements

    • Week One Done
      Nullun earned a badge
      Week One Done
    • First Post
      sultangris earned a badge
      First Post
    • Reacting Well
      sultangris earned a badge
      Reacting Well
    • First Post
      ClarkB earned a badge
      First Post
    • Week One Done
      Epaminombas earned a badge
      Week One Done
  • Popular Contributors

    1. 1
      +primortal
      160
    2. 2
      ATLien_0
      124
    3. 3
      Xenon
      120
    4. 4
      snowy owl
      109
    5. 5
      +Edouard
      97
  • Tell a friend

    Love Neowin? Tell a friend!