KStringHandler Namespace Reference
from PyKDE4.kdecore.KStringHandler import *
Detailed Description
This namespace contains utility functions for handling strings.
The functions here are intended to provide an easy way to cut/slice/splice words inside sentences in whatever order desired. While the main focus of KStringHandler is words (ie characters separated by spaces/tabs), the two core functions here (split() and join()) will allow you to use any character as a separator This will make it easy to redefine what a 'word' means in the future if needed.
The function names and calling styles are based on python and mIRC's scripting support.
The ranges are a fairly powerful way of getting/stripping words from a string. These ranges function, for the large part, as they would in python. See the word(const QString&, int) and remword(const QString&, int) functions for more detail.
The methods here are completely stateless. All strings are cut on the fly and returned as new qstrings/qstringlists.
Namespace for manipulating words and sentences in strings
- See also:
- KShell
Functions | |
QString | capwords (QString text) |
QStringList | capwords (QStringList list) |
QString | csqueeze (QString str, int maxlen=40) |
QString | from8Bit (QString str) |
bool | isUtf8 (QString str) |
QString | lsqueeze (QString str, int maxlen=40) |
int | naturalCompare (QString a, QString b, Qt::CaseSensitivity caseSensitivity=Qt.CaseSensitive) |
QString | obscure (QString str) |
QStringList | perlSplit (QString sep, QString s, int max=0) |
QStringList | perlSplit (QChar sep, QString s, int max=0) |
QStringList | perlSplit (QRegExp sep, QString s, int max=0) |
QString | preProcessWrap (QString text) |
QString | rsqueeze (QString str, int maxlen=40) |
QString | tagUrls (QString text) |
Function Documentation
Capitalizes each word in the list [hello, there] becomes [Hello, There] (list)
- Parameters:
-
list the list to capitalize
- Returns:
- the resulting list
QStringList capwords | ( | QStringList | list | |
) |
Capitalizes each word in the list [hello, there] becomes [Hello, There] (list)
- Parameters:
-
list the list to capitalize
- Returns:
- the resulting list
Substitute characters at the middle of a string by "...".
- Parameters:
-
str is the string to modify maxlen is the maximum length the modified string will have If the original string is shorter than "maxlen", it is returned verbatim
- Returns:
- the modified string
Construct QString from a c string, guessing whether it is UTF8- or Local8Bit-encoded.
- Parameters:
-
str the input string
- Returns:
- the (hopefully correctly guessed) QString representation of str
- See also:
- KEncodingDetector
bool isUtf8 | ( | QString | str | |
) |
Guess whether a string is UTF8 encoded.
- Parameters:
-
str the string to check
- Returns:
- true if UTF8. If false, the string is probably in Local8Bit.
Substitute characters at the beginning of a string by "...".
- Parameters:
-
str is the string to modify maxlen is the maximum length the modified string will have If the original string is shorter than "maxlen", it is returned verbatim
- Returns:
- the modified string
int naturalCompare | ( | QString | a, | |
QString | b, | |||
Qt::CaseSensitivity | caseSensitivity=Qt.CaseSensitive | |||
) |
Does a natural comparing of the strings. A negative value is returned if a is smaller than b. A positive value is returned if a is greater than b. 0 is returned if both values are equal.
- Parameters:
-
a first string to compare b second string to compare caseSensitivity whether to use case sensitive compare or not
- Since:
- 4.1
Obscure string by using a simple symmetric encryption. Applying the function to a string obscured by this function will result in the original string.
The function can be used to obscure passwords stored to configuration files. Note that this won't give you any more security than preventing that the password is directly copied and pasted.
- Parameters:
-
str string to be obscured
- Returns:
- obscured string
QStringList perlSplit | ( | QString | sep, | |
QString | s, | |||
int | max=0 | |||
) |
Split a QString into a QStringList in a similar fashion to the static QStringList function in Qt, except you can specify a maximum number of tokens. If max is specified (!= 0) then only that number of tokens will be extracted. The final token will be the remainder of the string.
Example:
perlSplit(QRegExp("[! ]"), "Split me up ! I'm bored ! OK ?", 3) QStringList contains: "Split", "me", "up ! I'm bored ! OK ?"
- Parameters:
-
sep is the regular expression to use to delimit s. s is the input string max is the maximum number of extractions to perform, or 0.
- Returns:
- A QStringList containing tokens extracted from s.
QStringList perlSplit | ( | QChar | sep, | |
QString | s, | |||
int | max=0 | |||
) |
Split a QString into a QStringList in a similar fashion to the static QStringList function in Qt, except you can specify a maximum number of tokens. If max is specified (!= 0) then only that number of tokens will be extracted. The final token will be the remainder of the string.
Example:
perlSplit(QRegExp("[! ]"), "Split me up ! I'm bored ! OK ?", 3) QStringList contains: "Split", "me", "up ! I'm bored ! OK ?"
- Parameters:
-
sep is the regular expression to use to delimit s. s is the input string max is the maximum number of extractions to perform, or 0.
- Returns:
- A QStringList containing tokens extracted from s.
QStringList perlSplit | ( | QRegExp | sep, | |
QString | s, | |||
int | max=0 | |||
) |
Split a QString into a QStringList in a similar fashion to the static QStringList function in Qt, except you can specify a maximum number of tokens. If max is specified (!= 0) then only that number of tokens will be extracted. The final token will be the remainder of the string.
Example:
perlSplit(QRegExp("[! ]"), "Split me up ! I'm bored ! OK ?", 3) QStringList contains: "Split", "me", "up ! I'm bored ! OK ?"
- Parameters:
-
sep is the regular expression to use to delimit s. s is the input string max is the maximum number of extractions to perform, or 0.
- Returns:
- A QStringList containing tokens extracted from s.
Preprocesses the given string in order to provide additional line breaking opportunities for QTextLayout.
This is done by inserting ZWSP (Zero-width space) characters in the string at points that wouldn't normally be considered word boundaries by QTextLayout, but where wrapping the text will produce good results.
Examples of such points includes after punctuation signs, underscores and dashes, that aren't followed by spaces.
- Since:
- 4.4
Substitute characters at the end of a string by "...".
- Parameters:
-
str is the string to modify maxlen is the maximum length the modified string will have If the original string is shorter than "maxlen", it is returned verbatim
- Returns:
- the modified string