以下はformat()
、Node.js 'util' モジュールから実際に取得された関数を含む Node.js モジュールです。util.format(format, [...])
date.js は Date プロトタイプに format() 関数を追加します。
プレースホルダの後に時間形式パターンを抽出できるように RegExpression を作成する方法は?
// from Node.js util module
util = require ('util');
inspect = util.inspect;
require('./date.js'); // adds .format to Date prototype
var formatRegExp = /%[sdjt%]/g; //+ t
exports.format = function(f) {
if (typeof f !== 'string') {
var objects = [];
for (var i = 0; i < arguments.length; i++) {
objects.push(inspect(arguments[i]));
}
return objects.join(' ');
}
var i = 1;
var args = arguments;
var len = args.length;
var str = String(f).replace(formatRegExp, function(x) {
if (x === '%%') return '%';
if (i >= len) return x;
switch (x) {
case '%s': return String(args[i++]);
case '%d': return Number(args[i++]);
case '%j': return JSON.stringify(args[i++]);
// added time = new Date().format('yyyy-MM-dd H:m:s');
case '%t': return args[i++].format('yyyy-MM-dd HH:mm:ss'); //+ added line
default:
return x;
}
});
for (var x = args[i]; i < len; x = args[++i]) {
if (x === null || typeof x !== 'object') {
str += ' ' + x;
} else {
str += ' ' + inspect(x);
}
}
return str;
};
正確な形式の使用をサポートする他のソリューションがあるかもしれません%t{yyyyMMdd-HHmm}
console.log( formatutil.format('log-%t{yyyyMMdd-HHmm}.log', curtime ) );
アップデート:
これは、RegExp が「log-%t{yyyyMMdd-HHmm}.log」で「%t{yyyyMMdd-HHmm}」をキャッチできるものです。