Transformer des nombres en mots dans un système Lakhs / Crores : une approche efficace
La conversion de nombres en mots est une tâche courante en programmation, en particulier dans applications financières ou comptables. Alors que de nombreuses solutions existantes impliquent un code complexe avec plusieurs expressions régulières et boucles, cet article présente une approche simplifiée adaptée aux exigences spécifiques du système de numérotation sud-asiatique.
Ce système utilise les concepts de « lakhs » et de « crores " pour représenter de grands nombres. Un lakh représente 100 000, tandis qu'un crore représente 10 000 000. Contrairement au système de numérotation occidental où les virgules sont utilisées comme séparateurs, le système sud-asiatique utilise des espaces.
Pour réaliser cette transformation efficacement, l'extrait de code suivant utilise une seule expression régulière et élimine le besoin de boucles :
<code class="javascript">const a = ['', 'one ', 'two ', 'three ', 'four ', 'five ', 'six ', 'seven ', 'eight ', 'nine ', 'ten ', 'eleven ', 'twelve ', 'thirteen ', 'fourteen ', 'fifteen ', 'sixteen ', 'seventeen ', 'eighteen ', 'nineteen ']; const b = ['', '', 'twenty', 'thirty', 'forty', 'fifty', 'sixty', 'seventy', 'eighty', 'ninety']; function inWords (num) { if ((num = num.toString()).length > 9) return 'overflow'; n = ('000000000' + num).substr(-9).match(/^(\d{2})(\d{2})(\d{2})(\d{1})(\d{2})$/); if (!n) return; let str = ''; str += (n[1] != 0) ? (a[Number(n[1])] || b[n[1][0]] + ' ' + a[n[1][1]]) + 'crore ' : ''; str += (n[2] != 0) ? (a[Number(n[2])] || b[n[2][0]] + ' ' + a[n[2][1]]) + 'lakh ' : ''; str += (n[3] != 0) ? (a[Number(n[3])] || b[n[3][0]] + ' ' + a[n[3][1]]) + 'thousand ' : ''; str += (n[4] != 0) ? (a[Number(n[4])] || b[n[4][0]] + ' ' + a[n[4][1]]) + 'hundred ' : ''; str += (n[5] != 0) ? ((str != '') ? 'and ' : '') + (a[Number(n[5])] || b[n[5][0]] + ' ' + a[n[5][1]]) + 'only ' : ''; return str; } ```` This code combines pre-defined arrays 'a' and 'b' to form various numerical representations. By utilizing a regular expression, it captures the different sections of the number (e.g., crores, lakhs, thousands, hundreds, and ones) and generates the appropriate words. Importantly, this approach is much more concise than the earlier solution presented. To demonstrate the code's functionality, an HTML/JavaScript snippet can be used: </code>
document.getElementById('number').onkeyup = function () {
document.getElementById('words').innerHTML = inWords(document.getElementById('number').value);
};
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!