52
62

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

JavaScriptで正規表現(文字列制限編)

Last updated at Posted at 2015-03-08

正規表現で文字列の置き換えを纏めてみました。

あまり自身ないんで、「おかしいよ」「こうした方がいいんじゃない」っていうのがあったらコメント下さい :smile:

なお、簡単なテストは通していますがすべてを網羅しているわけではありませんので、ご使用になる際にはご自身で十分検証の上ご利用下さい :bangbang:

/**
 * タブ文字をnum数のスペースに変換後、改行以外の制御文字を削除
 * 改行文字は\nに変換
 * 
 * @param {String} str 変換したい文字列
 * @param {Number} num スペースの文字数(デフォルトは4)
 */
var removeCtl = function (str, num) {
    num = parseInt(num, 10);
    var space = new Array(isNaN(num) ? 5 : num + 1).join(' ');
    return str
            .replace(/\t/g, space)
            .replace(/[\x00-\x09\x0b-\x1f\x7f-\x9f]/g, '')
            .replace(/\x0a/g, '\n');
};
/**
 * 改行の削除
 * 
 * @param {String} str 変換したい文字列
 */
var removeNl = function (str) {
    return str.replace(/\n/g, '');
};
/**
 * 全角スペースを含めたトリム
 * 「m」フラグを使用すると連続した改行が削除されることへの対策版
 *
 * @param {String} str 変換する文字列
 * @param {Boolean} multipleLines 各行ごとにトリムするかどうか(trueの時のみ各行トリム)
 * @param {Boolean} useBlankLine 空行を使用するかどうか(falseの時は空行削除)
 */
var trim = function (str, multipleLines, useBlankLine) {
    var reg = /^[\s ]+|[ \s]+$/g;
    if (multipleLines === true) {
        if (useBlankLine === false) {
            str = str.replace(/^[\s ]+|[ \s]+$/gm, '');
        } else {
            str = str
                    .split('\n')
                    .map(function (line) {
                        return line.replace(reg, '');
                    })
                    .join('\n')
                    .replace(reg, '');
        }
    } else {
        str = str.replace(reg, '');
    }
    return str;
};
/**
 * 全角スペースを含めた右トリム
 * 「m」フラグを使用すると連続した改行が削除されることへの対策版
 *
 * @param {String} str 変換する文字列
 * @param {Boolean} multipleLines 各行ごとにトリムするかどうか(trueの時のみ各行トリム)
 * @param {Boolean} useBlankLine 空行を使用するかどうか(falseの時は空行削除)
 */
var rtrim = function (str, multipleLines, useBlankLine) {
    var reg = /[ \s]+$/g;
    if (multipleLines === true) {
        if (useBlankLine === false) {
            str = str
                    .replace(/[ \s]+$/gm, '')
                    .replace(/^\n+/g, '');
        } else {
            str = str
                    .split('\n')
                    .map(function (line) {
                        return line.replace(reg, '');
                    })
                    .join('\n')
                    .replace(reg, '');
        }
    } else {
        str = str.replace(reg, '');
    }
    return str;
};
/**
 * 全角スペースを含めた左トリム
 * 「m」フラグを使用すると連続した改行が削除されることへの対策版
 *
 * @param {String} str 変換する文字列
 * @param {Boolean} multipleLines 各行ごとにトリムするかどうか(trueの時のみ各行トリム)
 * @param {Boolean} useBlankLine 空行を使用するかどうか(falseの時は空行削除)
 */
var ltrim = function (str, multipleLines, useBlankLine) {
    var reg = /^[\s ]+/g;
    if (multipleLines === true) {
        if (useBlankLine === false) {
            str = str
                    .split('\n')
                    .map(function (line) {
                        return line.replace(reg, '');
                    })
                    .join('\n')
                    .replace(reg, '')
                    .replace(/[\n\n]+/g, '\n')
                    .replace(/\n+$/g, '');
        } else {
            var split = str.split('\n');
            str = split.map(function (line) {
                return line.replace(reg, '');
            }).join('\n').replace(reg, '');
        }
    } else {
        str = str.replace(reg, '');
    }
    return str;
};
/**
 * 英字のみ(全角半角変換あり)
 * 
 * @param {String} str 変換したい文字列
 */
var alpha = function (str) {
    return str.replace(/[A-Za-z]/g, function (s) {
        return String.fromCharCode(s.charCodeAt(0) - 65248);
    }).replace(/[^A-Za-z]/g, '');
};
/**
 * 数字のみ(全角半角変換あり)
 * 
 * @param {String} str 変換したい文字列
 */
var num = function (str) {
    return str.replace(/[0-9]/g, function (s) {
        return String.fromCharCode(s.charCodeAt(0) - 65248);
    }).replace(/[^\d]/g, '');
};
/**
 * 英数字のみ(全角半角変換あり)
 * 
 * @param {String} str 変換したい文字列
 */
var alphaNum = function (str) {
    return str.replace(/[A-Za-z0-9]/g, function (s) {
        return String.fromCharCode(s.charCodeAt(0) - 65248);
    }).replace(/[^A-Za-z\d]/g, '');
};
/**
 * 数字とハイフンのみ(全角半角変換あり)
 * 全角ハイフン、全角ダッシュ、全角マイナス記号、長音符は半角ハイフンに変換
 * 
 * @param {String} str 変換したい文字列
 */
var numPyphen = function (str) {
    return str.replace(/[0-9]/g, function (s) {
        return String.fromCharCode(s.charCodeAt(0) - 65248);
    }).replace(/[‐-―ー]/g, '-').replace(/[^\d\-]/g, '');
};
/**
 * 数字とスラッシュ(全角半角変換あり)
 * 
 * @param {String} str 変換したい文字列
 **/
var numSlash = function (str) {
    return str.replace(/[0-9/]/g, function (s) {
        return String.fromCharCode(s.charCodeAt(0) - 65248);
    }).replace(/[^\d\/]/g, '');
};
/**
 * 数字とコロン(全角半角変換あり)
 * 
 * @param {String} str 変換したい文字列
 **/
var numColon = function (str) {
    return str.replace(/[0-9:]/g, function (s) {
        return String.fromCharCode(s.charCodeAt(0) - 65248);
    }).replace(/[^\d:]/g, '');
};
/**
 * ひらがなとスペース・長音符・半角ハイフン・半角数字のみ
 * 数字を半角に変換
 * 全角スペースを半角スペースに変換
 * 全角ハイフン、全角ダッシュ、全角マイナス記号は半角ハイフンに変換
 * 
 * @param {String} str 変換したい文字列
 **/
var hiragana = function (str) {
    return str
            .replace(/[0-9]/g, function (s) {
                return String.fromCharCode(s.charCodeAt(0) - 65248);
            })
            .replace(/゙/g, '')
            .replace(/゚/g, '')
            .replace(/ /g, ' ')
            .replace(/[‐-―]/g, '-')
            .replace(/[^ぁ-ゔーゝゞゕゖ゛゜ \d\-]/g, '');
};
/**
 * カタカナとスペース・長音符・半角ハイフン・半角数字のみ
 * 数字を半角に変換
 * 全角スペースを半角スペースに変換
 * 全角ハイフン、全角ダッシュ、全角マイナス記号は半角ハイフンに変換
 * 
 * @param {String} str 変換したい文字列
 **/
var katakana = function (str) {
    return str
            .replace(/[0-9]/g, function (s) {
                return String.fromCharCode(s.charCodeAt(0) - 65248);
            })
            .replace(/゙/g, '')
            .replace(/゚/g, '')
            .replace(/ /g, ' ')
            .replace(/[‐-―]/g, '-')
            .replace(/[^ァ-ヴーヽヾヵヶヷヸヹヺ゛゜ \d\-]/g, '');
};
52
62
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
52
62

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?