如何在 JavaScript 中输出带有前导零的数字? [复制]

Posted

技术标签:

【中文标题】如何在 JavaScript 中输出带有前导零的数字? [复制]【英文标题】:How to output numbers with leading zeros in JavaScript? [duplicate] 【发布时间】:2010-06-08 15:28:23 【问题描述】:

有没有办法在数字前面加上前导零,以便生成固定长度的字符串?例如,如果我指定 2 个地点,5 将变为 "05"

【问题讨论】:

我找到了this,我想这要简单得多:("00" + h).slice (-3); @PauloBueno ("00" + 1234).slice (-3); 给出234 即丢弃最重要的数字。 @DanielEarwicker 确实可以,但您应该调整到您期望的数字数量。 ("000" + 1234).slice(-4)("0000" + 12345).slice(-5) 等等…… 如果你还想限制数字的长度,你可以使用这个:return (num/Math.pow(10,size)).toFixed(size).split('.')[1]; 现在javascript支持padStart:(5).toString().padStart(3, "0") 【参考方案1】:

注意:可能已过时。 ECMAScript 2017 包括 String.prototype.padStart

您必须将数字转换为字符串,因为数字与前导零无关。像这样的:

function pad(num, size) 
    num = num.toString();
    while (num.length < size) num = "0" + num;
    return num;

或者,如果您知道您永远不会使用超过 X 个零,这可能会更好。这假设您永远不需要超过 10 位数字。

function pad(num, size) 
    var s = "000000000" + num;
    return s.substr(s.length-size);

如果您关心负数,则必须删除 - 并阅读它。

【讨论】:

第二个功能;更短:function pad(num, size) return ('000000000' + num).substr(-size); ^ 负值在许多版本的 IE 中都不起作用。 啊,显然 slice() 可以在 IE 中使用负值 :) ***.com/questions/2243824/… 也许是一个如何调用函数和结果的例子? 想通了:value = pad(value, 18); ==> 总是返回 18 个字符,所以如果你添加 10 个零的大小应该是 10。【参考方案2】:

更新:使用 ES2017 String.prototype.padStart 方法的小单行函数:

const zeroPad = (num, places) => String(num).padStart(places, '0')

console.log(zeroPad(5, 2)); // "05"
console.log(zeroPad(5, 4)); // "0005"
console.log(zeroPad(5, 6)); // "000005"
console.log(zeroPad(1234, 2)); // "1234"

另一种 ES5 方法:

function zeroPad(num, places) 
  var zero = places - num.toString().length + 1;
  return Array(+(zero > 0 && zero)).join("0") + num;


zeroPad(5, 2); // "05"
zeroPad(5, 4); // "0005"
zeroPad(5, 6); // "000005"
zeroPad(1234, 2); // "1234" :)

【讨论】:

您没有考虑负数组大小;)例如zeroPad(1234, 2) -> RangeError: Invalid array length 根据这个基准,这个方法比公认的解决方案慢 5 倍:gist.github.com/4382935 我喜欢这段代码,但它在 Chrome 中似乎速度较慢。有兴趣查看其他浏览器的结果:jsperf.com/zero-padding-number-methods 对于 Node.js,这是最好的解决方案。 GJ nodejs的最佳解决方案【参考方案3】:

您可以扩展 Number 对象:

Number.prototype.pad = function(size) 
    var s = String(this);
    while (s.length < (size || 2)) s = "0" + s;
    return s;

例子:

(9).pad();  //returns "09"

(7).pad(3);  //returns "007"

【讨论】:

我认为这正是我所需要的。参数“大小”指的是最终字符数,而不是要添加的零的总数,对吧? 是的,确实如此,它会检查总长度并进行比较。 是的,这取决于您在哪里使用它。这本质上并不是一件坏事,但如果在有很多第三方参与的空间中使用,则可能存在覆盖功能的风险。 (9).pad()(7).pad(3) 带括号! 这个问题不是全局的,也和IE6没有关系。问题是永久性的。它在几年前被发现的事实并没有让它消失。问题是语言本身在进化。谁说你的.pad() 会像原生版本一样工作,它应该出现吗?我找不到我原来的评论。希望这只是 Stack Overflow 中的一个错误。如果它被删除,那将是对周围事物状态的不良反映。【参考方案4】:

来自https://gist.github.com/1180489

function pad(a, b)
  return(1e15 + a + '').slice(-b);

使用 cmets:

function pad(
  a, // the number to convert 
  b // number of resulting characters
)
  return (
    1e15 + a + // combine with large number
    "" // convert to string
  ).slice(-b) // cut leading "1"

【讨论】:

这很好,但它有一个致命的缺陷。例如,pad (1234, 3) === "234"!这显然是不可接受的。 如果你想要超过 15 的填充,它也会被破坏。优雅,但相当不灵活。 @dave1010 我得到了一个不好的结果 pad(1234) 产生 "1000000000001234" 。带参数pad(1234,20) 产生"1000000000001234" 谢谢@Brock Adams @JamesThomasMoon1979,见this answer。它不仅可以正常工作(而大多数其他答案在许多测试用例中都失败了),而且它的性能明显优于其他方法——尤其是如果您使用 cmets 中链接的对数变化。 满足我的需要,我就是喜欢它。简单的。另一种看待事物的方式。不像每个人。想法不同!以上所有方法也各有利弊。【参考方案5】:
function zfill(num, len) return (Array(len).join("0") + num).slice(-len);

【讨论】:

当你发布代码时选择它并点击按钮,这样它就会被格式化。 zfill(1234, 3) === "234" function zFill(n,l)return (l>n.toString().length)?((Array(l).join('0')+n).slice(-l )):n;【参考方案6】:

只是为了好玩(我有一些时间可以杀死),一个缓存零字符串的更复杂的实现:

pad.zeros = new Array(5).join('0');
function pad(num, len) 
    var str = String(num),
        diff = len - str.length;
    if(diff <= 0) return str;
    if(diff > pad.zeros.length)
        pad.zeros = new Array(diff + 1).join('0');
    return pad.zeros.substr(0, diff) + str;

如果填充计数很大并且函数被足够频繁地调用,它实际上优于其他方法......

【讨论】:

以上是关于如何在 JavaScript 中输出带有前导零的数字? [复制]的主要内容,如果未能解决你的问题,请参考以下文章

如何打印带有前导零的二进制整数?

如何将带有前导零的数字字符串转储为 yaml-cpp 中的有效 yaml 字符串?

如何格式化带有前导零的Java字符串?

Excel:如何像数据透视表一样对一系列带有前导零的数字进行排序?

使用vba在excel中复制带有前导零的数字文本

在 C 中存储前导零