NAME
subst - Greple module for text substitution
VERSION
Version 1.01
SYNOPSIS
greple -Msubst [ options ]
--subst-file spec_file
--subst-from string
--subst-to string
--diff
--diffcmd command
--create
--replace
DESCRIPTION
This greple module supports word substitution in text data.
Substitution can be indicated by option --subst-from and --subst-to, or specification file.
Next command replaces all string "FROM" to "TO".
greple -Msubst --subst-from FROM --subst-to TO FROM
Of course, you should rather use sed in this case. Option --subst-from and --subst-to can be repeated, and substitution is done in order.
Using --subst-file option, you can prepare these substitution list in the file. Suppose the file cotains following data:
Monday Mon.
Tuesday The.
Wednesday Wed.
Thursday Thu.
Friday Fri.
Saturday Sat.
Sunday Sun.
Next command converts day-of-week name to abbreviation form.
greple -Msubst --subst-file SPEC '\b[A-Z][a-z]+' ...
Field "//" in spec file is ignored, so this file can be written like this:
Monday // Mon.
Tuesday // The.
Wednesday // Wed.
Thursday // Thu.
Friday // Fri.
Saturday // Sat.
Sunday // Sun.
You can use same file by greple's -f option and string after "//" is ignored as a comment in that case.
greple -Msubst --subst-file SPEC -f SPEC ...
This is equivalent to search next pattern, and replace them. This is bad example, though.
Monday|Tuesday|Wednesday|Thursday|Friday|Saturday|Sunday
Actually, it takes the second last field as a target, and the last field as a substitution string. All other fields are ignored. This behavior is useful when the pattern requires longer text than the string to be converted. See the next example:
Black-\KMonday // Monday Friday
Pattern matches to string "Monday", but requires string "Black-" is preceeding to it. Substitution is done just for string "Monday", which does not match to the original pattern. As a matter of fact, look-ahead and look-behind pattern is removed automatically, next example works as expected.
(?<=Black-)Monday // Friday
Combining with greple's other options, it is possible to convert strings in the specific area of the target files.
- --diff
-
Produce diff output of original and converted text.
- --diffcmd command
-
Specify diff command name used by --diff option. Default is "diff -u".
- --create
-
Create new file and write the result. Suffix ".new" is appended to original filename.
- --replace
-
Replace the target file by converted result. Original file is renamed to backup name with ".bak" suffix.
BUGS
This module is made for Japanese text processing, and it is difficult to imagine the useful situation handling ascii.
LICENSE
Copyright (C) Kazumasa Utashiro.
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
SEE ALSO
https://github.com/kaz-utashiro/greple-msdoc
AUTHOR
Kazumasa Utashiro