CopperSpice API
1.9.1
|
Provides functionality for parsing a string. More...
Public Typedefs | |
using | SectionFlags = QFlags< SectionFlag > |
Public Types | |
enum | SectionFlag |
enum | SplitBehavior |
Static Public Methods | |
template<typename T , typename V , typename = typename std::enable_if<! std::is_arithmetic<typename std::remove_reference<V>::type>::value>::type> | |
static T | formatArg (const T &str, V &&value, int fieldwidth=0, QChar32 fillChar=QChar32 (' ')) |
template<typename T , typename V , typename = typename std::enable_if<std::is_floating_point<V>::value>::type> | |
static T | formatArg (const T &str, V value, int fieldwidth=0, char format= 'g', int precision=6, QChar32 fillChar=QChar32 (' ')) |
template<typename T , typename V , typename = typename std::enable_if<std::is_integral<V>::value>::type> | |
static T | formatArg (const T &str, V value, int fieldwidth=0, int base=10, QChar32 fillChar=QChar32 (' ')) |
template<typename T , typename... Ts> | |
static T | formatArgs (const T &str, Ts...args) |
template<typename T , typename V > | |
static T | join (const QList< T > &list, const V &separator) |
template<typename T = QString8> | |
static T | number (double value, char format= 'g', int precision=6) |
template<typename T = QString8, typename V > | |
static T | number (V value, int base=10) |
template<typename T > | |
static T | section (const T &str, const QRegularExpression &separator, int firstSection, int lastSection=-1, SectionFlags flags=SectionDefault) |
template<typename T > | |
static T | section (const T &str, const T &separator, int firstSection, int lastSection=-1, SectionFlags flags=SectionDefault) |
template<typename T > | |
static T | section (const T &str, QChar32 separator, int firstSection, int lastSection=-1, SectionFlags flags=SectionDefault) |
template<typename T > | |
static QList< T > | split (const T &str, const QRegularExpression ®Exp, SplitBehavior behavior=KeepEmptyParts) |
template<typename T > | |
static QList< T > | split (const T &str, const T &separator, SplitBehavior behavior=KeepEmptyParts, Qt::CaseSensitivity cs=Qt::CaseSensitive) |
template<typename T > | |
static QList< T > | split (const T &str, QChar32 separator, SplitBehavior behavior=KeepEmptyParts, Qt::CaseSensitivity cs=Qt::CaseSensitive) |
template<typename T = QString8> | |
static double | toDouble (const T &str, bool *ok=nullptr) |
template<typename T = QString8> | |
static float | toFloat (const T &str, bool *ok=nullptr) |
template<typename R , typename T = QString8> | |
static R | toInteger (const T &str, bool *ok=nullptr, int base=10) |
This class provides functionality to parse an existing string. This class provides several methods for converting strings into numbers. Refer to setNum() number(), toInt(), toDouble(), and similar methods. There are also several methods for converting numbers into strings. Refer to formatArg() and formatArgs().
To split a string into a substrings based on a separator, use split(). To merge a list of strings into one single string with a specified separator, use join().
In methods where an argument format can be specified the argument can be any of those shown in the following table. The value for precision represents the maximum number of significant digits (trailing zeroes are omitted).
Format | Description |
---|---|
e | format as [-]9.9e[+|-]999 |
E | format as [-]9.9E[+|-]999 |
f | format as [-]9.9 |
g | use e or f format, whichever is the most concise |
G | use E or f format, whichever is the most concise |
Typedef for QFlags<SectionFlag> which contains an OR combination of SectionFlag values.
Refer to QStringParser::SectionFlag for the enum documentation.
This enum specifies flags which can be used to affect the outcome of the section() method.
Constant | Value | Description |
---|---|---|
QStringParser::SectionDefault | 0x00 | Empty section are counted, leading and trailing separators are not included, and the separator is compared case sensitively. |
QStringParser::SectionSkipEmpty | 0x01 | Treat empty sections as if they do not exist. |
QStringParser::SectionIncludeLeadingSep | 0x02 | Include the leading separator (if any) in the result string. |
QStringParser::SectionIncludeTrailingSep | 0x04 | Include the trailing separator (if any) in the string. |
QStringParser::SectionCaseInsensitiveSeps | 0x08 | Compare the separator case-insensitively. |
|
nodiscardinlinestatic |
Returns a copy of string str with the lowest numbered place marker replaced by the value. Place marker numbers must be in the range 1 to 99 and preceded with a % sign.
If a same place marker appears more than once in str, they will all be replaced with the appropriate value.
The fieldwidth specifies the minimum amount of space the argument shall occupy. If str requires less space than fieldwidth the output is padded to fieldwidth with character fillChar. A positive value for fieldwidth produces right-aligned text whereas a negative fieldwidth produces left-aligned text.
The data type for the template parameter V can be char, QChar, QChar32, QString, QString8, QString16, or any data type which can be appended to the string type of T.
|
nodiscardinlinestatic |
Returns a copy of the string str with the lowest numbered place marker replaced by value formatted according to the specified format and precision. Place marker numbers must be in the range 1 to 99 and preceded with a % sign.
If a same place marker appears more than once in str, they will all be replaced with the appropriate value.
The fieldwidth specifies the minimum amount of space the argument shall occupy. If str requires less space than fieldwidth the output is padded to fieldwidth with character fillChar. A positive value for fieldwidth produces right-aligned text whereas a negative fieldwidth produces left-aligned text.
The '%'
can be followed by an 'L' in which case the sequence is replaced with a localized representation of value. The conversion uses the default locale set by QLocale::setDefaultLocale(). If no default locale was specified the "C" locale is used.
Refer to Argument Formats for details.
|
nodiscardinlinestatic |
Returns a copy of the string str with the lowest numbered place marker replaced by value using the base specified by base. Place marker numbers must be in the range 1 to 99 and preceded with a % sign. The value is expressed in base, which is 10 by default and must be between 2 and 36.
If a same place marker appears more than once in str, they will all be replaced with the appropriate value.
The fieldwidth specifies the minimum amount of space the argument shall occupy. If str requires less space than fieldwidth the output is padded to fieldwidth with character fillChar. A positive value for fieldwidth produces right-aligned text whereas a negative fieldwidth produces left-aligned text.
The '%'
used in the place marker can be followed by an 'L' in which case the sequence is replaced with a localized representation of value. The conversion uses the default locale set by QLocale::setDefaultLocale(). If no default locale was specified the "C" locale is used.
The data type for the template parameter V can be int, short, ushort, long, qint64, quint64, or any integral data type.
Refer to Argument Formats for more details.
|
nodiscardinlinestatic |
Returns a copy of string str with the numbered place markers replaced by the arguments args. The number of arguments for args is variable and unlimited.
This following shows two different ways to create a string used to display a progress status. The code to format status1 and status2 will produce the same result. The second example one is faster and more accurate since the arguments will be replaced in one pass.
|
static |
Joins all the strings in a list into one single string with each element separated by the given separator. The separator can be empty.
The data type for the template parameter V can be char, QChar, QChar32, QString, QString8, QString16, or any data type which can be appended to the string type of T.
|
nodiscardinlinestatic |
Returns a string equivalent of the number value formatted according to the specified format and precision. Unlike QLocale::toString() this method does not honor the user's locale settings.
Refer to Argument Formats for additional information.
|
nodiscardinlinestatic |
Returns a string equivalent of the number value according to the specified base. The default base is 10 and must be between 2 and 36. For bases other than 10 value is treated as an unsigned integer.
The data type for the template parameter V can be int, short, ushort, long, qint64, quint64, or any integral data type.
|
static |
This method overload is used when str is a string and separator is a QRegularExpression.
|
static |
|
inlinestatic |
The string str is treated as a sequence of fields separated by the character separator. The return value is a string containing fields from position firstSection to position lastSection inclusive.
If lastSection is not specified all of the fields from position firstSection to the end of the string are included. Fields are numbered 0, 1, 2, etc. starting from the beginning of str. To index from the end of str use a negative number. A value of -1 will return the last field.
The flags are used to adjust the str is split. For example, based on case sensitivity, if empty sections should be skipped, or how to deal with leading and trailing separators.
|
static |
Splits the string into substrings where the regular expression regExp matches. If regExp does not match anywhere in the string, split() returns a single element list containing this string.
The following example extracts the words in a sentence using one or more whitespace characters as the separator.
The following example uses a word boundary assertion to split the string into an alternating sequence of non-word and word tokens.
|
static |
Splits the string str into substrings using the separator as the marker indicating where to break. Returns a list of the substrings in a QList. If separator does not match anywhere in the string, split() will return a single element in the list containing the passed string.
The value for cs specifies whether separator should be matched case sensitively or case insensitively. If behavior is QStringParser::SkipEmptyParts then empty entries do not appear in the result. By default empty entries are retained.
|
static |
Splits the string str into substrings using the code point separator as the marker, which indicates where to break. Returns a list of the substrings in a QList. If separator does not match anywhere in the string, split() will return a single element in the list containing the passed string.
The value for cs specifies whether separator should be matched case sensitively or case insensitively.
If behavior is QStringParser::SkipEmptyParts then empty entries do not appear in the result. By default empty entries are retained.
|
inlinestatic |
Returns the string str converted to a double value. The return value is 0.0 if the conversion fails. If a conversion error occurs ok is set to false, otherwise it is set to true. The string conversion will always use the 'C' locale. For locale aware string parsing use QLocale methods such as QLocale::toDouble().
The string may only contain a valid floating point number, the plus/minus sign, a decimal point, or the characters g and e for scientific notation.
|
inlinestatic |
Returns the string str converted to a float value. Returns 0.0 if the conversion fails. If a conversion error occurs ok is set to false, otherwise it is set to true. The string conversion will always use the 'C' locale. For locale aware string parsing use QLocale methods such as QLocale::toFloat().
The string may only contain a valid floating point number, the plus/minus sign, a decimal point, or the characters g and e for scientific notation.
|
inlinestatic |
Returns the given str converted to an integer of type T using the specified base. The base is 10 by default and must be between 2 and 36. If the base value is 0 the beginning of the string is used to deduce the base. If the string begins with "0x" base 16 is used, if the string begins with "0" base 8 is used, otherwise base 10 is used.
The return value is 0 if the conversion fails. If a conversion error occurs ok is set to false, otherwise it is set to true.