Recursive directory find files replace string using fileInput module. How?











up vote
0
down vote

favorite












I am creating a simple python script to find and replace strings inside of files which are also inside of sub-folders and so on. This calls for recursion.



The following script finds and replaces a string for another string found in every file inside of every folder of the target parent folder.



I've found this post on here suggesting the use of fileinput module in order to avoid reading entire files into memory which could slow things down...



...simplify the text replacement in a file without requiring to read the whole file in memory...



Credits @jfs



Python is very dynamic and honestly, I get lost on the many different ways to accomplish the same task.



How can I integrate this approach into my script below?



import subprocess, os, fnmatch

if os.name == 'nt':
def clear_console():
subprocess.call("cls", shell=True)
return
else:
def clear_console():
subprocess.call("clear", shell=True)
return

# Globals
menuChoice = 0
searchCounter = 0

# Recursive find/replace with file extension argument.
def findReplace(directory, find, replace, fileExtension):

global searchCounter

#For all paths, sub-directories & files in (directory)...
for path, dirs, files in os.walk(os.path.abspath(directory)):
#For each file found with (FileExtension)...
for filename in fnmatch.filter(files, fileExtension):
#Construct the target file path...
filepath = os.path.join(path, filename)
#Open file correspondent to target filepath.
with open(filepath) as f:
# Read it into memory.
s = f.read()
# Find and replace all occurrances of (find).
s = s.replace(find, replace)
# Write these new changes to the target file path.
with open(filepath, "w") as f:
f.write(s)
# increment search counter by one.
searchCounter += 1

# Report final status.
print (' Files Searched: ' + str(searchCounter))
print ('')
print (' Search Status : Complete')
print ('')
input (' Press any key to exit...')

def mainMenu():
global menuChoice
global searchCounter

# range lowest index is 1 so range of 6 is 1 through 7.
while int(menuChoice) not in range(1,1):

clear_console()
print ('')
print (' frx v1.0 - Menu')
print ('')
print (' A. Select target file type extension.')
print (' B. Enter target directory name. eg -> target_directory/target_subfolder')
print (' C. Enter string to Find.')
print (' D. Enter string to Replace.')
print ('')
print (' Menu')
print ('')

menuChoice = input('''
1. All TXT files. (*.txt )

Enter Option: ''')
print ('')

# Format as int
menuChoice = int(menuChoice)

if menuChoice == 1:

fextension = '*.txt'

# Set directory name
tdirectory = input(' Target directory name? ')
tdirectory = str(tdirectory)
print ('')

# Set string to Find
fstring = input(' String to find? (Ctrl + V) ')
fstring = str(fstring)
print ('')

# Set string to Replace With
rstring = input(' Replace with string? (Ctrl + V) ')
rstring = str(rstring)
print ('')

# Report initial status
print (' Searching for occurrences of ' + fstring)
print (' Please wait...')
print ('')

# Call findReplace function
findReplace('./' + tdirectory, fstring, rstring, fextension)

# Initialize program
mainMenu()

# Action Sample...
#findReplace("in this dir", "find string 1", "replace with string 2", "of this file extension")

# Confirm.
#print("done.")









share|improve this question






















  • I would guess to do the for line in FileInput(files, inplace=True):line.replace(text, replacement) part, and for files use fnmatch.filter(files, fileExtension)
    – Peter
    Nov 22 at 15:46















up vote
0
down vote

favorite












I am creating a simple python script to find and replace strings inside of files which are also inside of sub-folders and so on. This calls for recursion.



The following script finds and replaces a string for another string found in every file inside of every folder of the target parent folder.



I've found this post on here suggesting the use of fileinput module in order to avoid reading entire files into memory which could slow things down...



...simplify the text replacement in a file without requiring to read the whole file in memory...



Credits @jfs



Python is very dynamic and honestly, I get lost on the many different ways to accomplish the same task.



How can I integrate this approach into my script below?



import subprocess, os, fnmatch

if os.name == 'nt':
def clear_console():
subprocess.call("cls", shell=True)
return
else:
def clear_console():
subprocess.call("clear", shell=True)
return

# Globals
menuChoice = 0
searchCounter = 0

# Recursive find/replace with file extension argument.
def findReplace(directory, find, replace, fileExtension):

global searchCounter

#For all paths, sub-directories & files in (directory)...
for path, dirs, files in os.walk(os.path.abspath(directory)):
#For each file found with (FileExtension)...
for filename in fnmatch.filter(files, fileExtension):
#Construct the target file path...
filepath = os.path.join(path, filename)
#Open file correspondent to target filepath.
with open(filepath) as f:
# Read it into memory.
s = f.read()
# Find and replace all occurrances of (find).
s = s.replace(find, replace)
# Write these new changes to the target file path.
with open(filepath, "w") as f:
f.write(s)
# increment search counter by one.
searchCounter += 1

# Report final status.
print (' Files Searched: ' + str(searchCounter))
print ('')
print (' Search Status : Complete')
print ('')
input (' Press any key to exit...')

def mainMenu():
global menuChoice
global searchCounter

# range lowest index is 1 so range of 6 is 1 through 7.
while int(menuChoice) not in range(1,1):

clear_console()
print ('')
print (' frx v1.0 - Menu')
print ('')
print (' A. Select target file type extension.')
print (' B. Enter target directory name. eg -> target_directory/target_subfolder')
print (' C. Enter string to Find.')
print (' D. Enter string to Replace.')
print ('')
print (' Menu')
print ('')

menuChoice = input('''
1. All TXT files. (*.txt )

Enter Option: ''')
print ('')

# Format as int
menuChoice = int(menuChoice)

if menuChoice == 1:

fextension = '*.txt'

# Set directory name
tdirectory = input(' Target directory name? ')
tdirectory = str(tdirectory)
print ('')

# Set string to Find
fstring = input(' String to find? (Ctrl + V) ')
fstring = str(fstring)
print ('')

# Set string to Replace With
rstring = input(' Replace with string? (Ctrl + V) ')
rstring = str(rstring)
print ('')

# Report initial status
print (' Searching for occurrences of ' + fstring)
print (' Please wait...')
print ('')

# Call findReplace function
findReplace('./' + tdirectory, fstring, rstring, fextension)

# Initialize program
mainMenu()

# Action Sample...
#findReplace("in this dir", "find string 1", "replace with string 2", "of this file extension")

# Confirm.
#print("done.")









share|improve this question






















  • I would guess to do the for line in FileInput(files, inplace=True):line.replace(text, replacement) part, and for files use fnmatch.filter(files, fileExtension)
    – Peter
    Nov 22 at 15:46













up vote
0
down vote

favorite









up vote
0
down vote

favorite











I am creating a simple python script to find and replace strings inside of files which are also inside of sub-folders and so on. This calls for recursion.



The following script finds and replaces a string for another string found in every file inside of every folder of the target parent folder.



I've found this post on here suggesting the use of fileinput module in order to avoid reading entire files into memory which could slow things down...



...simplify the text replacement in a file without requiring to read the whole file in memory...



Credits @jfs



Python is very dynamic and honestly, I get lost on the many different ways to accomplish the same task.



How can I integrate this approach into my script below?



import subprocess, os, fnmatch

if os.name == 'nt':
def clear_console():
subprocess.call("cls", shell=True)
return
else:
def clear_console():
subprocess.call("clear", shell=True)
return

# Globals
menuChoice = 0
searchCounter = 0

# Recursive find/replace with file extension argument.
def findReplace(directory, find, replace, fileExtension):

global searchCounter

#For all paths, sub-directories & files in (directory)...
for path, dirs, files in os.walk(os.path.abspath(directory)):
#For each file found with (FileExtension)...
for filename in fnmatch.filter(files, fileExtension):
#Construct the target file path...
filepath = os.path.join(path, filename)
#Open file correspondent to target filepath.
with open(filepath) as f:
# Read it into memory.
s = f.read()
# Find and replace all occurrances of (find).
s = s.replace(find, replace)
# Write these new changes to the target file path.
with open(filepath, "w") as f:
f.write(s)
# increment search counter by one.
searchCounter += 1

# Report final status.
print (' Files Searched: ' + str(searchCounter))
print ('')
print (' Search Status : Complete')
print ('')
input (' Press any key to exit...')

def mainMenu():
global menuChoice
global searchCounter

# range lowest index is 1 so range of 6 is 1 through 7.
while int(menuChoice) not in range(1,1):

clear_console()
print ('')
print (' frx v1.0 - Menu')
print ('')
print (' A. Select target file type extension.')
print (' B. Enter target directory name. eg -> target_directory/target_subfolder')
print (' C. Enter string to Find.')
print (' D. Enter string to Replace.')
print ('')
print (' Menu')
print ('')

menuChoice = input('''
1. All TXT files. (*.txt )

Enter Option: ''')
print ('')

# Format as int
menuChoice = int(menuChoice)

if menuChoice == 1:

fextension = '*.txt'

# Set directory name
tdirectory = input(' Target directory name? ')
tdirectory = str(tdirectory)
print ('')

# Set string to Find
fstring = input(' String to find? (Ctrl + V) ')
fstring = str(fstring)
print ('')

# Set string to Replace With
rstring = input(' Replace with string? (Ctrl + V) ')
rstring = str(rstring)
print ('')

# Report initial status
print (' Searching for occurrences of ' + fstring)
print (' Please wait...')
print ('')

# Call findReplace function
findReplace('./' + tdirectory, fstring, rstring, fextension)

# Initialize program
mainMenu()

# Action Sample...
#findReplace("in this dir", "find string 1", "replace with string 2", "of this file extension")

# Confirm.
#print("done.")









share|improve this question













I am creating a simple python script to find and replace strings inside of files which are also inside of sub-folders and so on. This calls for recursion.



The following script finds and replaces a string for another string found in every file inside of every folder of the target parent folder.



I've found this post on here suggesting the use of fileinput module in order to avoid reading entire files into memory which could slow things down...



...simplify the text replacement in a file without requiring to read the whole file in memory...



Credits @jfs



Python is very dynamic and honestly, I get lost on the many different ways to accomplish the same task.



How can I integrate this approach into my script below?



import subprocess, os, fnmatch

if os.name == 'nt':
def clear_console():
subprocess.call("cls", shell=True)
return
else:
def clear_console():
subprocess.call("clear", shell=True)
return

# Globals
menuChoice = 0
searchCounter = 0

# Recursive find/replace with file extension argument.
def findReplace(directory, find, replace, fileExtension):

global searchCounter

#For all paths, sub-directories & files in (directory)...
for path, dirs, files in os.walk(os.path.abspath(directory)):
#For each file found with (FileExtension)...
for filename in fnmatch.filter(files, fileExtension):
#Construct the target file path...
filepath = os.path.join(path, filename)
#Open file correspondent to target filepath.
with open(filepath) as f:
# Read it into memory.
s = f.read()
# Find and replace all occurrances of (find).
s = s.replace(find, replace)
# Write these new changes to the target file path.
with open(filepath, "w") as f:
f.write(s)
# increment search counter by one.
searchCounter += 1

# Report final status.
print (' Files Searched: ' + str(searchCounter))
print ('')
print (' Search Status : Complete')
print ('')
input (' Press any key to exit...')

def mainMenu():
global menuChoice
global searchCounter

# range lowest index is 1 so range of 6 is 1 through 7.
while int(menuChoice) not in range(1,1):

clear_console()
print ('')
print (' frx v1.0 - Menu')
print ('')
print (' A. Select target file type extension.')
print (' B. Enter target directory name. eg -> target_directory/target_subfolder')
print (' C. Enter string to Find.')
print (' D. Enter string to Replace.')
print ('')
print (' Menu')
print ('')

menuChoice = input('''
1. All TXT files. (*.txt )

Enter Option: ''')
print ('')

# Format as int
menuChoice = int(menuChoice)

if menuChoice == 1:

fextension = '*.txt'

# Set directory name
tdirectory = input(' Target directory name? ')
tdirectory = str(tdirectory)
print ('')

# Set string to Find
fstring = input(' String to find? (Ctrl + V) ')
fstring = str(fstring)
print ('')

# Set string to Replace With
rstring = input(' Replace with string? (Ctrl + V) ')
rstring = str(rstring)
print ('')

# Report initial status
print (' Searching for occurrences of ' + fstring)
print (' Please wait...')
print ('')

# Call findReplace function
findReplace('./' + tdirectory, fstring, rstring, fextension)

# Initialize program
mainMenu()

# Action Sample...
#findReplace("in this dir", "find string 1", "replace with string 2", "of this file extension")

# Confirm.
#print("done.")






python python-3.x file recursion directory






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 22 at 15:36









ASPiRE

1,09852246




1,09852246












  • I would guess to do the for line in FileInput(files, inplace=True):line.replace(text, replacement) part, and for files use fnmatch.filter(files, fileExtension)
    – Peter
    Nov 22 at 15:46


















  • I would guess to do the for line in FileInput(files, inplace=True):line.replace(text, replacement) part, and for files use fnmatch.filter(files, fileExtension)
    – Peter
    Nov 22 at 15:46
















I would guess to do the for line in FileInput(files, inplace=True):line.replace(text, replacement) part, and for files use fnmatch.filter(files, fileExtension)
– Peter
Nov 22 at 15:46




I would guess to do the for line in FileInput(files, inplace=True):line.replace(text, replacement) part, and for files use fnmatch.filter(files, fileExtension)
– Peter
Nov 22 at 15:46












2 Answers
2






active

oldest

votes

















up vote
0
down vote



accepted










Your check that the inputs are '.txt' files is good; it relieves you of needing to worry about passing 'rb' or 'wb' to open().



You say you don't want to allocate N bytes for an N-byte file, for fear that occasionally N may be quite large. Better to limit the memory allocation to size of longest text line rather than size of biggest file. Let's break out a helper function. Delete / replace these lines:



            #Open file correspondent to target filepath.
with open(filepath) as f:
# Read it into memory.
s = f.read()
# Find and replace all occurrances of (find).
s = s.replace(find, replace)
# Write these new changes to the target file path.
with open(filepath, "w") as f:
f.write(s)
# increment search counter by one.
searchCounter += 1


with a call to the helper function and then a bump of the counter:



            update(filepath, find, replace)
searchCounter += 1


and then define the helper:



def update(filepath, find, replace, temp_fspec='temp'):
assert temp_fspec != filepath, filepath
with open(filepath) as fin:
with open(temp_fspec) as fout:
for line in fin:
fout.write(line.replace(find, replace))
os.rename(temp_fspec, filepath) # overwrites filepath


Using fileinput is not relevant, since that would catenate lines from many inputs into a single output stream, and your requirement is to associate each output with its own input. The for line in idiom is what matters here, and it works the same in fileinput as in the suggested update() helper.



Consider putting unusual characters in temp_fspec to reduce the chance of collision, or perhaps make it a fully qualified path in the same filesystem but above the affected subtree so it's guaranteed to never collide.



This version should typically take a little longer to run, especially for lengthy files full of short lines. Maximum memory footprint for this version should be much smaller, if max file size >> max line length. If very long lines are a concern, then a binary chunking approach would be more appropriate, finessing the case where find might span a chunk boundary. We needn't handle that case in the current code if we assume that find does not contain 'n' newlines.



We can simplify two versions of your clear screen routine down to one by phrasing it this way:



def clear_console():
clear = 'cls' if os.name == 'nt' else 'clear'
subprocess.call(clear, shell=True)
return





share|improve this answer






























    up vote
    0
    down vote













    I believe you can also check glob library. This will help you go through the directories and sub directories and you can also update the name of file. I found below link from stack overflow relevant to your question:



    How can I search sub-folders using glob.glob module in Python?






    share|improve this answer





















      Your Answer






      StackExchange.ifUsing("editor", function () {
      StackExchange.using("externalEditor", function () {
      StackExchange.using("snippets", function () {
      StackExchange.snippets.init();
      });
      });
      }, "code-snippets");

      StackExchange.ready(function() {
      var channelOptions = {
      tags: "".split(" "),
      id: "1"
      };
      initTagRenderer("".split(" "), "".split(" "), channelOptions);

      StackExchange.using("externalEditor", function() {
      // Have to fire editor after snippets, if snippets enabled
      if (StackExchange.settings.snippets.snippetsEnabled) {
      StackExchange.using("snippets", function() {
      createEditor();
      });
      }
      else {
      createEditor();
      }
      });

      function createEditor() {
      StackExchange.prepareEditor({
      heartbeatType: 'answer',
      convertImagesToLinks: true,
      noModals: true,
      showLowRepImageUploadWarning: true,
      reputationToPostImages: 10,
      bindNavPrevention: true,
      postfix: "",
      imageUploader: {
      brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
      contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
      allowUrls: true
      },
      onDemand: true,
      discardSelector: ".discard-answer"
      ,immediatelyShowMarkdownHelp:true
      });


      }
      });














      draft saved

      draft discarded


















      StackExchange.ready(
      function () {
      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53434253%2frecursive-directory-find-files-replace-string-using-fileinput-module-how%23new-answer', 'question_page');
      }
      );

      Post as a guest















      Required, but never shown

























      2 Answers
      2






      active

      oldest

      votes








      2 Answers
      2






      active

      oldest

      votes









      active

      oldest

      votes






      active

      oldest

      votes








      up vote
      0
      down vote



      accepted










      Your check that the inputs are '.txt' files is good; it relieves you of needing to worry about passing 'rb' or 'wb' to open().



      You say you don't want to allocate N bytes for an N-byte file, for fear that occasionally N may be quite large. Better to limit the memory allocation to size of longest text line rather than size of biggest file. Let's break out a helper function. Delete / replace these lines:



                  #Open file correspondent to target filepath.
      with open(filepath) as f:
      # Read it into memory.
      s = f.read()
      # Find and replace all occurrances of (find).
      s = s.replace(find, replace)
      # Write these new changes to the target file path.
      with open(filepath, "w") as f:
      f.write(s)
      # increment search counter by one.
      searchCounter += 1


      with a call to the helper function and then a bump of the counter:



                  update(filepath, find, replace)
      searchCounter += 1


      and then define the helper:



      def update(filepath, find, replace, temp_fspec='temp'):
      assert temp_fspec != filepath, filepath
      with open(filepath) as fin:
      with open(temp_fspec) as fout:
      for line in fin:
      fout.write(line.replace(find, replace))
      os.rename(temp_fspec, filepath) # overwrites filepath


      Using fileinput is not relevant, since that would catenate lines from many inputs into a single output stream, and your requirement is to associate each output with its own input. The for line in idiom is what matters here, and it works the same in fileinput as in the suggested update() helper.



      Consider putting unusual characters in temp_fspec to reduce the chance of collision, or perhaps make it a fully qualified path in the same filesystem but above the affected subtree so it's guaranteed to never collide.



      This version should typically take a little longer to run, especially for lengthy files full of short lines. Maximum memory footprint for this version should be much smaller, if max file size >> max line length. If very long lines are a concern, then a binary chunking approach would be more appropriate, finessing the case where find might span a chunk boundary. We needn't handle that case in the current code if we assume that find does not contain 'n' newlines.



      We can simplify two versions of your clear screen routine down to one by phrasing it this way:



      def clear_console():
      clear = 'cls' if os.name == 'nt' else 'clear'
      subprocess.call(clear, shell=True)
      return





      share|improve this answer



























        up vote
        0
        down vote



        accepted










        Your check that the inputs are '.txt' files is good; it relieves you of needing to worry about passing 'rb' or 'wb' to open().



        You say you don't want to allocate N bytes for an N-byte file, for fear that occasionally N may be quite large. Better to limit the memory allocation to size of longest text line rather than size of biggest file. Let's break out a helper function. Delete / replace these lines:



                    #Open file correspondent to target filepath.
        with open(filepath) as f:
        # Read it into memory.
        s = f.read()
        # Find and replace all occurrances of (find).
        s = s.replace(find, replace)
        # Write these new changes to the target file path.
        with open(filepath, "w") as f:
        f.write(s)
        # increment search counter by one.
        searchCounter += 1


        with a call to the helper function and then a bump of the counter:



                    update(filepath, find, replace)
        searchCounter += 1


        and then define the helper:



        def update(filepath, find, replace, temp_fspec='temp'):
        assert temp_fspec != filepath, filepath
        with open(filepath) as fin:
        with open(temp_fspec) as fout:
        for line in fin:
        fout.write(line.replace(find, replace))
        os.rename(temp_fspec, filepath) # overwrites filepath


        Using fileinput is not relevant, since that would catenate lines from many inputs into a single output stream, and your requirement is to associate each output with its own input. The for line in idiom is what matters here, and it works the same in fileinput as in the suggested update() helper.



        Consider putting unusual characters in temp_fspec to reduce the chance of collision, or perhaps make it a fully qualified path in the same filesystem but above the affected subtree so it's guaranteed to never collide.



        This version should typically take a little longer to run, especially for lengthy files full of short lines. Maximum memory footprint for this version should be much smaller, if max file size >> max line length. If very long lines are a concern, then a binary chunking approach would be more appropriate, finessing the case where find might span a chunk boundary. We needn't handle that case in the current code if we assume that find does not contain 'n' newlines.



        We can simplify two versions of your clear screen routine down to one by phrasing it this way:



        def clear_console():
        clear = 'cls' if os.name == 'nt' else 'clear'
        subprocess.call(clear, shell=True)
        return





        share|improve this answer

























          up vote
          0
          down vote



          accepted







          up vote
          0
          down vote



          accepted






          Your check that the inputs are '.txt' files is good; it relieves you of needing to worry about passing 'rb' or 'wb' to open().



          You say you don't want to allocate N bytes for an N-byte file, for fear that occasionally N may be quite large. Better to limit the memory allocation to size of longest text line rather than size of biggest file. Let's break out a helper function. Delete / replace these lines:



                      #Open file correspondent to target filepath.
          with open(filepath) as f:
          # Read it into memory.
          s = f.read()
          # Find and replace all occurrances of (find).
          s = s.replace(find, replace)
          # Write these new changes to the target file path.
          with open(filepath, "w") as f:
          f.write(s)
          # increment search counter by one.
          searchCounter += 1


          with a call to the helper function and then a bump of the counter:



                      update(filepath, find, replace)
          searchCounter += 1


          and then define the helper:



          def update(filepath, find, replace, temp_fspec='temp'):
          assert temp_fspec != filepath, filepath
          with open(filepath) as fin:
          with open(temp_fspec) as fout:
          for line in fin:
          fout.write(line.replace(find, replace))
          os.rename(temp_fspec, filepath) # overwrites filepath


          Using fileinput is not relevant, since that would catenate lines from many inputs into a single output stream, and your requirement is to associate each output with its own input. The for line in idiom is what matters here, and it works the same in fileinput as in the suggested update() helper.



          Consider putting unusual characters in temp_fspec to reduce the chance of collision, or perhaps make it a fully qualified path in the same filesystem but above the affected subtree so it's guaranteed to never collide.



          This version should typically take a little longer to run, especially for lengthy files full of short lines. Maximum memory footprint for this version should be much smaller, if max file size >> max line length. If very long lines are a concern, then a binary chunking approach would be more appropriate, finessing the case where find might span a chunk boundary. We needn't handle that case in the current code if we assume that find does not contain 'n' newlines.



          We can simplify two versions of your clear screen routine down to one by phrasing it this way:



          def clear_console():
          clear = 'cls' if os.name == 'nt' else 'clear'
          subprocess.call(clear, shell=True)
          return





          share|improve this answer














          Your check that the inputs are '.txt' files is good; it relieves you of needing to worry about passing 'rb' or 'wb' to open().



          You say you don't want to allocate N bytes for an N-byte file, for fear that occasionally N may be quite large. Better to limit the memory allocation to size of longest text line rather than size of biggest file. Let's break out a helper function. Delete / replace these lines:



                      #Open file correspondent to target filepath.
          with open(filepath) as f:
          # Read it into memory.
          s = f.read()
          # Find and replace all occurrances of (find).
          s = s.replace(find, replace)
          # Write these new changes to the target file path.
          with open(filepath, "w") as f:
          f.write(s)
          # increment search counter by one.
          searchCounter += 1


          with a call to the helper function and then a bump of the counter:



                      update(filepath, find, replace)
          searchCounter += 1


          and then define the helper:



          def update(filepath, find, replace, temp_fspec='temp'):
          assert temp_fspec != filepath, filepath
          with open(filepath) as fin:
          with open(temp_fspec) as fout:
          for line in fin:
          fout.write(line.replace(find, replace))
          os.rename(temp_fspec, filepath) # overwrites filepath


          Using fileinput is not relevant, since that would catenate lines from many inputs into a single output stream, and your requirement is to associate each output with its own input. The for line in idiom is what matters here, and it works the same in fileinput as in the suggested update() helper.



          Consider putting unusual characters in temp_fspec to reduce the chance of collision, or perhaps make it a fully qualified path in the same filesystem but above the affected subtree so it's guaranteed to never collide.



          This version should typically take a little longer to run, especially for lengthy files full of short lines. Maximum memory footprint for this version should be much smaller, if max file size >> max line length. If very long lines are a concern, then a binary chunking approach would be more appropriate, finessing the case where find might span a chunk boundary. We needn't handle that case in the current code if we assume that find does not contain 'n' newlines.



          We can simplify two versions of your clear screen routine down to one by phrasing it this way:



          def clear_console():
          clear = 'cls' if os.name == 'nt' else 'clear'
          subprocess.call(clear, shell=True)
          return






          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited Nov 22 at 18:38

























          answered Nov 22 at 18:30









          J_H

          3,1231616




          3,1231616
























              up vote
              0
              down vote













              I believe you can also check glob library. This will help you go through the directories and sub directories and you can also update the name of file. I found below link from stack overflow relevant to your question:



              How can I search sub-folders using glob.glob module in Python?






              share|improve this answer

























                up vote
                0
                down vote













                I believe you can also check glob library. This will help you go through the directories and sub directories and you can also update the name of file. I found below link from stack overflow relevant to your question:



                How can I search sub-folders using glob.glob module in Python?






                share|improve this answer























                  up vote
                  0
                  down vote










                  up vote
                  0
                  down vote









                  I believe you can also check glob library. This will help you go through the directories and sub directories and you can also update the name of file. I found below link from stack overflow relevant to your question:



                  How can I search sub-folders using glob.glob module in Python?






                  share|improve this answer












                  I believe you can also check glob library. This will help you go through the directories and sub directories and you can also update the name of file. I found below link from stack overflow relevant to your question:



                  How can I search sub-folders using glob.glob module in Python?







                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 22 at 18:47









                  Neha Bhushan

                  64




                  64






























                      draft saved

                      draft discarded




















































                      Thanks for contributing an answer to Stack Overflow!


                      • Please be sure to answer the question. Provide details and share your research!

                      But avoid



                      • Asking for help, clarification, or responding to other answers.

                      • Making statements based on opinion; back them up with references or personal experience.


                      To learn more, see our tips on writing great answers.





                      Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


                      Please pay close attention to the following guidance:


                      • Please be sure to answer the question. Provide details and share your research!

                      But avoid



                      • Asking for help, clarification, or responding to other answers.

                      • Making statements based on opinion; back them up with references or personal experience.


                      To learn more, see our tips on writing great answers.




                      draft saved


                      draft discarded














                      StackExchange.ready(
                      function () {
                      StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53434253%2frecursive-directory-find-files-replace-string-using-fileinput-module-how%23new-answer', 'question_page');
                      }
                      );

                      Post as a guest















                      Required, but never shown





















































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown

































                      Required, but never shown














                      Required, but never shown












                      Required, but never shown







                      Required, but never shown







                      Popular posts from this blog

                      How to ignore python UserWarning in pytest?

                      What visual should I use to simply compare current year value vs last year in Power BI desktop

                      Script to remove string up to first number