frep 
Find, replace and string tranformation utility for node.js. Modify strings by passing an array or object of RegExp or string replacement patterns. Patterns can be strings, arrays of strings or regex, replacements can be strings or functions.
Quickstart
Install with npm:
npm i frep --save-dev
Usage:
var replace = require('frep');
var replacements = [
{
pattern: 'a',
replacement: 'x'
},
{
pattern: /b/,
replacement: 'y'
},
{
pattern: /c[\S]+/,
replacement: function(match) {
return match.toUpperCase();
}
}
];
console.log(replace.strWithArr('abcdefg', replacements));
API
replace.strWithArr(String, replacements);
replace.arrWithArr(Array, replacements);
replace.strWithObj(String, replacements);
replace.arrWithObj(Array, replacements);
.strWithArr( string, array )
Transform a string with an array of replacement patterns.
Parameters:
String
: The string to modify with the given replacement patterns.
Array
: Array of objects containing the replacement patterns, each including a pattern
property (which can be a string or a RegExp), and a replacement
property (which can be a string or a function to be called for each match).
- A new string is returned with some or all matches replaced by the given replacement patterns.
Example 1
Given the following:
var str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
var patterns = [
{
pattern: /[ABC]/g,
replacement: '###'
},
{
pattern: /[XYZ]/g,
replacement: '$$$'
},
...
];
replace.strWithArr(str, patterns));
patterns as arrays
Patterns may also be arrays. When replacement patterns are formatted as arrays Frep will first transform the array into a corresponding RegExp group:
Example 2
['[ABC]', '[XYZ]']
gets converted to:
/([ABC]|[XYZ])/gi
Example 3
So the following will produce a similar result to Example 1, except ###
is used to replace all patterns:
var str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
var patterns = [
{
pattern: ['[ABC]', '[XYZ]'],
replacement: '###'
}
];
replace.strWithArr(str, patterns));
.arrWithArr( array, array )
Transform an array of strings with an array of replacement patterns
Parameters:
Array
: The string to modify with the given replacement patterns.
Array
: Same as replacStr
, this is an an array of objects containing the replacement patterns, each including a pattern
property, which can be a string or a RegExp, and a replacement
property, which can be a string or a function to be called for each match.
- A new array of strings is returned with some or all matches replaced by the given replacement patterns.
Given the following:
Example 4
var arr = [
'Jon Schlinkert',
'Brian Woodward'
];
var patterns = [
{
pattern: /(B|S)/g,
replacement: '###'
},
{
pattern: /(J|W)/g,
replacement: '$$$'
},
...
];
replace.arrWithArr(arr, patterns));
An array of new strings is returned, with some or all matches in each string replaced by the given replacement strings.
.strWithObj( string, object )
Transform a string with an object of replacement patterns
Parameters:
String
: The string to modify with the given replacement patterns.
Object
: Object of replacement patterns, where each key is a string or a RegExp pattern
, and each value is the replacement
string or function to be called for each match.
- A new string is returned with some or all matches replaced by the given replacement patterns.
Example 5
Given the following:
var str = 'ABC'
var replacements = {
'A': 'AAA',
'B': 'BBB',
'C': 'CCC',
'D': 'DDD',
'E': 'EEE',
'F': 'FFF'
};
replace.strWithObj(str, replacements));
.arrWithObj( array, object )
Transform an array of strings with an object of replacement patterns
Parameters:
Array
: The array of strings to modify with the given replacement patterns.
Object
: Object of replacement patterns, where each key is a string or a RegExp pattern
, and each value is the replacement
string or function to be called for each match.
- A new array of strings is returned with some or all matches replaced by the given replacement patterns.
Example 6
Given the following:
var arr = ['ABC', 'DEF'];
var replacements = {
'A': 'AAA',
'B': 'BBB',
'C': 'CCC',
'D': 'DDD',
'E': 'EEE',
'F': 'FFF'
};
replace.arrWithObj(arr, replacements));
Usage example
replace.strWithArray( string, array )
Slugify URL segments using frep
To run the example, first do: npm install frep underscore.string
var replace = require('frep');
var _str = require('underscore.string');
var slugger = function(str) {
return str.replace(/( |-|\.)/g, '_').toLowerCase();
};
var sluggifier = function(str) {
return str.replace(/( |\.)/g, '-');
};
var obj = {
foo: 'This is foo.',
bar: 'ThIs iS bAr.',
baz: 'THIS is BAZ.',
};
var patterns = [
{
pattern: /:foo/g,
replacement: _str.slugify(obj.foo)
},
{
pattern: /:bar/g,
replacement: slugger(obj.bar)
},
{
pattern: /:baz/g,
replacement: sluggifier(obj.baz)
}
];
console.log(replace.strWithArr(':foo/:bar/:baz', patterns));
Author
Jon Schlinkert
License
Copyright (c) 2014 Jon Schlinkert, contributors.
Released under the MIT license
This file was generated by verb-cli on May 14, 2014.