Je veux savoir comment je peux trouver et remplacer un texte spécifique dans plusieurs fichiers, comme dans Notepad ++ dans le tutoriel lié.
par exemple: http://cybernetnews.com/find-replace-multiple-files/
Je veux savoir comment je peux trouver et remplacer un texte spécifique dans plusieurs fichiers, comme dans Notepad ++ dans le tutoriel lié.
par exemple: http://cybernetnews.com/find-replace-multiple-files/
Réponses:
Ici, j’utilise sed pour remplacer chaque occurrence du mot "cybernetnews" par "cybernet" dans chaque fichier portant l’extension c dans le répertoire / home / user / directory /.
find /home/user/directory -name \*.c -exec sed -i "s/cybernetnews/cybernet/g" {} \;
Une variante plus générique dans laquelle vous effectuez une recherche récursive dans le répertoire d'exécution et ne travaillez que sur des fichiers normaux, lisibles et inscriptibles:
find ./ -type f -readable -writable -exec sed -i "s/cybernetnews/cybernet/g" {} \;
cyber net news
? Comment puis-je convertir cela en cyber net
?
L'éditeur de flux, sed, est un utilitaire puissant pour ce type de travail. C'est mon premier choix. Toutefois, si vous souhaitez utiliser un éditeur de texte ordinaire utilisant une application native basée sur Ubuntu, je vous suggère de jeter un coup d'œil à Jedit. , Il est disponible dans les référentiels et peut être installé en tapant dans votre console:
sudo apt-get install jedit
Lancez jedit, cliquez sur l'élément de menu de recherche, dans la liste de menu, cliquez sur l'élément de recherche dans le répertoire. La boîte de dialogue ci-dessous s'affichera:
Ceci est similaire à celui de Notepad ++ et fait la même chose, je crois que c'est ce que vous voulez.
sed
.
Regexxer est une autre option de l'interface graphique :
Vérifiez auprès de Geany , il s’agit du remplacement parfait de NPP pour Linux. Vous pouvez faire exactement cela, plus vous pouvez utiliser regex.
J'ai écrit un petit script pour cette chose. Si vous avez seulement besoin des bases et que vous n'êtes pas familiarisé avec sed, etc., consultez la page suivante : http://www.csrdu.org/nauman/2010/12/30/bash-script-to-find-and-replace-in -a-set-of-files /
Le script est le suivant:
for f in submit_*;
do sed "s/old_db_name/new_db_name/" < $f > a_$f ;
mv a_$f $f ;
done
Vous pouvez utiliser ce script, copier du code et créer un fichier find_and_replace_in_files.sh
.
Je l'ai un peu modifié; s'il vous plaît dites-moi votre opinion.
# *****************************************************************************************
# find_and_replace_in_files.sh
# This script does a recursive, case sensitive directory search and replace of files
# To make a case insensitive search replace, use the -i switch in the grep call
# uses a startdirectory parameter so that you can run it outside of specified directory - else this script will modify itself!
# *****************************************************************************************
!/bin/bash
# **************** Change Variables Here ************
startdirectory="/your/start/directory"
searchterm="test"
replaceterm="test=ok!"
# **********************************************************
echo "***************************************************"
echo "* Search and Replace in Files Version 01-Aug-2012 *"
echo "***************************************************"
i=0;
for file in $(grep -l -R $searchterm $startdirectory)
do
cp $file $file.bak
sed -e "s/$searchterm/$replaceterm/ig" $file > tempfile.tmp
mv tempfile.tmp $file
let i++;
echo "Modified: " $file
done
echo " *** All Done! *** Modified files:" $i
Searchmonkey est un autre programme .
SearchMonkey est une application Gtk légère qui vise à remplacer le fastidieux find / grep par une interface utilisateur épurée qui fournit rapidement une annotation indiquant les emplacements et le nombre de correspondances de texte. L'objectif est de fournir un outil de recherche simple à utiliser et accessible aux utilisateurs finaux et aux développeurs de logiciels.
find . -name "*.txt" |xargs sed -i "s/searched_Text/replacement_Text/g"
travaille pour moi sur fedora
sed
instances! C'est donc beaucoup plus rapide en termes de temps de calcul. Le temps d’accès aux fichiers étant limité, je pense que le temps d’horloge n’est pas beaucoup plus rapide, mais que la charge du système est réduite. Note xargs
mettra beaucoup, comme des centaines, de noms de fichiers sur la ligne de commande d'une seule sed
commande - en remplissant la taille de la mémoire tampon disponible en fonction de la longueur des chemins.
+
au lieu de \;
dans find
, non?
xargs
, mais vous avez raison; de man find
: -exec command {} +
... The command line is built in much the same way that xargs...
. Cela me fait penser aux lignes de commande de git filter-branch
...;)
Une solution très simple: remplacez dans tous les *.txt
fichiers du dossier string_1
par string_2
:
sed -i 's/string_1/string_2/g' *.txt
sed -i 's/string_1/string_2/g' $(grep -rEl 'string_1' ./)