parseNumber: Difference between revisions

From Bohemia Interactive Community
mNo edit summary
(Added more details about parsing hex numbers)
 
(65 intermediate revisions by 7 users not shown)
Line 1: Line 1:
{{Command|= Comments
{{RV|type=command
____________________________________________________________________________________________


| arma |= Game name
|game1= arma1
|version1= 1.00


|1.00|= Game version
|game2= arma2
____________________________________________________________________________________________
|version2= 1.00


| Parses the string, interpreting its content as a floating point number.
|game3= arma2oa
<br>The command first discards as many whitespace characters as necessary until the first non-whitespace character is found. Then, starting from this character, takes as many characters as possible that are valid following a syntax resembling that of [https://community.bistudio.com/wiki/Floating_Point_Number#Floating_Point_Literals floating point literals], and interprets them as a numerical value. The rest of the string after the last valid character is ignored and has no effect on the behavior of this command.
|version3= 1.50
<br>If the first sequence of non-whitespace characters in string does not form a valid floating-point number, or if no such sequence exists because either string is empty or contains only whitespace characters, no conversion is performed and the command returns 0. |= Description
____________________________________________________________________________________________


| '''parseNumber''' string |= Syntax
|game4= tkoh
|version4= 1.00


|p1= string: [[String]] |= Parameter 1
|game5= arma3
|version5= 0.50


| [[Number]] |= Return value
|gr1= Strings
____________________________________________________________________________________________
 
|x1= <code>_number = [[parseNumber]] "0.125";</code> |= Example 1


|x2= <code>_number = [[parseNumber]] "2 abc";//2</code> |= Example 2
|descr= Parses the string, interpreting its content as a floating point number.
____________________________________________________________________________________________
{{Feature|important|This command does '''not''' work with strings representing hexadecimal numbers (e.g {{hl|"0xCF"}}).
<sqf>
parseNumber "512 + 0x2F"; // 512, WRONG!
"512 + 0x2F" call BIS_fnc_parseNumber // 559, CORRECT!
</sqf>}}
{{Feature|informative|Starting whitespaces are discarded, then as many valid characters are used to be interpreted as a number until an invalid character is found then the rest of the string is ignored.}}


| [[BIS_fnc_parseNumber]] |= See also
|s1= [[parseNumber]] value


}}
|p1= value: [[String]] or {{GVI|arma3|1.50|size= 0.75}} [[Boolean]]
 
|r1= [[Number]] - the parsed number, {{hl|0}} if no valid number was found; in the case of a passed [[Boolean]], 0 if [[false]], 1 if [[true]]


<h3 style="display:none">Notes</h3>
|x1= <sqf>
<dl class="command_description">
_number = parseNumber "0.125"; // 0.125
<!-- Note Section BEGIN -->
_number = parseNumber "0050"; // 50
<dd class="notedate">Posted on Aug 28, 2014
_number = parseNumber " 42 yes"; // 42
<dt class="note">[[User:ffur2007slx2_5|ffur2007slx2_5]]
_number = parseNumber "3 or 4"; // 3
<dd class="note"> (A3 1.26)It only detects the first occurrence of a number in the string, return 0 by default.
_number = parseNumber "either 3 or 4"; // 0
<code>[[parseNumber]] "2s4f"; // 2
_number = parseNumber "0xCF"; // 0
[[parseNumber]] "s2f4"; // 0</code>
</sqf>
parse config or code, currently [[BIS_fnc_parseNumber]], occurrence is only limited with number, return -1 by default.
<code>{s3s4f} [[call]] [[BIS_fnc_parseNumber]]; // -1</code>
<!-- Note Section END -->
</dl>


<h3 style="display:none">Bottom Section</h3>
|x2= since {{arma3}} v1.50:
[[Category:Scripting Commands|PARSENUMBER]]
<sqf>
[[Category:Scripting Commands ArmA|PARSENUMBER]]
_result = parseNumber false; // 0
[[Category:Command_Group:_Variables|{{uc:{{PAGENAME}}}}]]
_result = parseNumber true; // 1
[[Category:Scripting Commands ArmA2|{{uc:{{PAGENAME}}}}]]
_zeroOneStatus = parseNumber alive player; // 0 if the player is dead, 1 if alive
[[Category:Scripting Commands Arma 3|{{uc:{{PAGENAME}}}}]]
</sqf>
[[Category:Scripting_Commands_Take_On_Helicopters|{{uc:{{PAGENAME}}}}]]


<!-- CONTINUE Notes -->
|seealso= [[BIS_fnc_parseNumber]] {{Link|http://www.cplusplus.com/reference/cstdlib/atof/|atof (C++)}} [[Floating Point Number#Floating Point Literals|Floating point literals]]
<dl class="command_description">
}}
<dd class="notedate">Posted on October 3, 2014 - 22:21 (UTC)</dd>
<dt class="note">[[User:DreadedEntity|DreadedEntity]]</dt>
<dd class="note">
For clarity, the output of parseNumber only reflects numbers found before the first non-numeric character.
<!-- DISCONTINUE Notes -->

Latest revision as of 11:39, 10 May 2024

Hover & click on the images for description

Description

Description:
Parses the string, interpreting its content as a floating point number.
This command does not work with strings representing hexadecimal numbers (e.g "0xCF").
parseNumber "512 + 0x2F"; // 512, WRONG! "512 + 0x2F" call BIS_fnc_parseNumber // 559, CORRECT!
Starting whitespaces are discarded, then as many valid characters are used to be interpreted as a number until an invalid character is found then the rest of the string is ignored.
Groups:
Strings

Syntax

Syntax:
parseNumber value
Parameters:
value: String or Arma 3 logo black.png 1.50 Boolean
Return Value:
Number - the parsed number, 0 if no valid number was found; in the case of a passed Boolean, 0 if false, 1 if true

Examples

Example 1:
_number = parseNumber "0.125"; // 0.125 _number = parseNumber "0050"; // 50 _number = parseNumber " 42 yes"; // 42 _number = parseNumber "3 or 4"; // 3 _number = parseNumber "either 3 or 4"; // 0 _number = parseNumber "0xCF"; // 0
Example 2:
since Arma 3 v1.50:
_result = parseNumber false; // 0 _result = parseNumber true; // 1 _zeroOneStatus = parseNumber alive player; // 0 if the player is dead, 1 if alive

Additional Information

See also:
BIS_fnc_parseNumber atof (C++) Floating point literals

Notes

Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note