Skip to content

nlohmann::basic_json::is_number

constexpr bool is_number() const noexcept;

This function returns true if and only if the JSON value is a number. This includes both integer (signed and unsigned) and floating-point values.

Return value

true if type is number (regardless whether integer, unsigned integer or floating-type), false otherwise.

Exception safety

No-throw guarantee: this member function never throws exceptions.

Complexity

Constant.

Possible implementation

constexpr bool is_number() const noexcept
{
    return is_number_integer() || is_number_float();
}

Examples

Example

The following code exemplifies is_number() for all JSON types.

#include <iostream>
#include <nlohmann/json.hpp>

using json = nlohmann::json;

int main()
{
    // create JSON values
    json j_null;
    json j_boolean = true;
    json j_number_integer = 17;
    json j_number_unsigned_integer = 12345678987654321u;
    json j_number_float = 23.42;
    json j_object = {{"one", 1}, {"two", 2}};
    json j_array = {1, 2, 4, 8, 16};
    json j_string = "Hello, world";
    json j_binary = json::binary({1, 2, 3});

    // call is_number()
    std::cout << std::boolalpha;
    std::cout << j_null.is_number() << '\n';
    std::cout << j_boolean.is_number() << '\n';
    std::cout << j_number_integer.is_number() << '\n';
    std::cout << j_number_unsigned_integer.is_number() << '\n';
    std::cout << j_number_float.is_number() << '\n';
    std::cout << j_object.is_number() << '\n';
    std::cout << j_array.is_number() << '\n';
    std::cout << j_string.is_number() << '\n';
    std::cout << j_binary.is_number() << '\n';
}

Output:

false
false
true
true
true
false
false
false
false

See also

Version history

  • Added in version 1.0.0.
  • Extended to also return true for unsigned integers in 2.0.0.

Last update: May 1, 2022