string


Functions

capitalize_start

Capitalizes start of string.

delimit_words

Delimits words in string.

from_roman

Changes string from Roman numeral to digits.

is_lilypond_identifier

Is true when string starts with a letter and either 1.

is_roman

Is true when string is Roman numeral.

is_shout_case

Is true when string and is shoutcase.

normalize

Normalizes string.

pluralize

Pluralizes English string.

sort_roman

Sorts strings containing Roman numerals.

strip_roman

Strips roman numerals from right of string.

to_shout_case

Changes string to shout case.

to_tridirectional_lilypond_symbol

Changes argument to tridirectional LilyPond symbol.

to_tridirectional_ordinal_constant

Changes argument to tridirectional ordinal constant.

to_upper_camel_case

Changes string to upper camel case.

abjad.string.capitalize_start(string: str) str[source]

Capitalizes start of string.

Capitalizes only string[0]; leaves noninitial characters unchanged:

>>> abjad.string.capitalize_start("violin I")
'Violin I'

Built-in str.capitalize() forces noninitial characters to lowercase:

>>> "violin I".capitalize()
'Violin i'
abjad.string.delimit_words(string: str, separate_caps: bool = False) list[str][source]

Delimits words in string.

>>> abjad.string.delimit_words("scale degrees 4 and 5.")
['scale', 'degrees', '4', 'and', '5']
>>> abjad.string.delimit_words("scale degrees 4and5.")
['scale', 'degrees', '4', 'and', '5']
>>> abjad.string.delimit_words("scaleDegrees4and5.")
['scale', 'Degrees', '4', 'and', '5']
>>> abjad.string.delimit_words("ScaleDegrees4and 5.")
['Scale', 'Degrees', '4', 'and', '5']
>>> abjad.string.delimit_words("scale-degrees-4-and-5.")
['scale', 'degrees', '4', 'and', '5']
>>> abjad.string.delimit_words("SCALE_DEGREES_4_AND_5.")
['SCALE', 'DEGREES', '4', 'AND', '5']
>>> abjad.string.delimit_words("one < two")
['one', '<', 'two']
>>> abjad.string.delimit_words("one! two!")
['one', '!', 'two', '!']

Separates capital letters when keyword is true:

>>> abjad.string.delimit_words("MRM")
['MRM']
>>> abjad.string.delimit_words("MRM", separate_caps=True)
['M', 'R', 'M']
>>> abjad.string.delimit_words("MRhM")
['MRh', 'M']
>>> abjad.string.delimit_words("MRhM", separate_caps=True)
['M', 'Rh', 'M']
abjad.string.from_roman(string: str) int[source]

Changes string from Roman numeral to digits.

>>> abjad.string.from_roman("IX")
9
>>> abjad.string.from_roman("ix")
9

Raises Roman numeral error when string is not Roman numeral:

>>> abjad.string.from_roman("Allegro")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/Users/trevor/abjad/abjad/string.py", line 143, in from_roman
    number = roman.fromRoman(string)
             ^^^^^^^^^^^^^^^^^^^^^^^
  File "/Users/trevor/.venv/abjad/lib/python3.12/site-packages/roman.py", line 107, in fromRoman
    raise InvalidRomanNumeralError('Invalid Roman numeral: %s' % s)
roman.InvalidRomanNumeralError: Invalid Roman numeral: Allegro
abjad.string.is_lilypond_identifier(string: str) bool[source]

Is true when string starts with a letter and either 1. contains only letters and underscores thereafter, or 2. contains only letters, numbers and dots thereafter.

>>> abjad.string.is_lilypond_identifier("ViolinOne")
True
>>> abjad.string.is_lilypond_identifier("Violin_One")
True
>>> abjad.string.is_lilypond_identifier("Violin One")
False
>>> abjad.string.is_lilypond_identifier("ViolinI")
True
>>> abjad.string.is_lilypond_identifier("Violin_I")
True
>>> abjad.string.is_lilypond_identifier("Violin I")
False
>>> abjad.string.is_lilypond_identifier("Violin1")
False
>>> abjad.string.is_lilypond_identifier("Violin_1")
False
>>> abjad.string.is_lilypond_identifier("Violin 1")
False
>>> abjad.string.is_lilypond_identifier("Violin.1")
True
>>> abjad.string.is_lilypond_identifier("Violin.1.1")
False
>>> abjad.string.is_lilypond_identifier("Violin.1_1")
False
>>> abjad.string.is_lilypond_identifier("Violin_1.1")
False
>>> abjad.string.is_lilypond_identifier("Violin.1.MusicVoice.1")
True
>>> abjad.string.is_lilypond_identifier("Violin.1.1.MusicVoice")
False
>>> abjad.string.is_lilypond_identifier("Violin.1_Music_Voice")
False
>>> abjad.string.is_lilypond_identifier("Violin.Music_Voice_1")
False
>>> abjad.string.is_lilypond_identifier("Violin.1_Music_Voice")
False
abjad.string.is_roman(string: str) bool[source]

Is true when string is Roman numeral.

>>> abjad.string.is_roman("I")
True
>>> abjad.string.is_roman("II")
True
>>> abjad.string.is_roman("X")
True
>>> abjad.string.is_roman("XI")
True
>>> abjad.string.is_roman("C")
True
>>> abjad.string.is_roman("CI")
True
>>> abjad.string.is_roman("i")
True
>>> abjad.string.is_roman("F")
False
abjad.string.is_shout_case(string: str) bool[source]

Is true when string and is shoutcase.

>>> abjad.string.is_shout_case("FOO_BAR")
True
>>> abjad.string.is_shout_case("FooBar")
False
abjad.string.normalize(argument: str, indent: int | str | None = None) str[source]

Normalizes string.

>>> string = r"""
...     foo
...         bar
... """
>>> print(string)

    foo
        bar

>>> print(abjad.string.normalize(string))
foo
    bar
>>> print(abjad.string.normalize(string, indent=4))
    foo
        bar
>>> print(abjad.string.normalize(string, indent="* "))
* foo
*     bar
abjad.string.pluralize(string: str, count: int | None = None) str[source]

Pluralizes English string.

Changes terminal -y to -ies:

>>> abjad.string.pluralize("catenary")
'catenaries'

Adds -es to terminal -s, -sh, -x and -z:

>>> abjad.string.pluralize("brush")
'brushes'

Adds -s to all other strings:

>>> abjad.string.pluralize("shape")
'shapes'

Does not pluralize when count is 1:

>>> abjad.string.pluralize("shape", count=1)
'shape'
abjad.string.sort_roman(strings: list[str]) list[str][source]

Sorts strings containing Roman numerals.

>>> strings = ["TromboneII", "TromboneIII", "TromboneI"]
>>> abjad.string.sort_roman(strings)
['TromboneI', 'TromboneII', 'TromboneIII']
>>> strings = ["ViolinXI", "ViolinX", "ViolinIX"]
>>> abjad.string.sort_roman(strings)
['ViolinIX', 'ViolinX', 'ViolinXI']
abjad.string.strip_roman(string: str) str[source]

Strips roman numerals from right of string.

>>> abjad.string.strip_roman("Trombone")
'Trombone'
>>> abjad.string.strip_roman("TromboneI")
'Trombone'
>>> abjad.string.strip_roman("TromboneII")
'Trombone'
>>> abjad.string.strip_roman("TromboneIII")
'Trombone'
>>> abjad.string.strip_roman("TromboneIV")
'Trombone'
abjad.string.to_shout_case(string: str) str[source]

Changes string to shout case.

>>> abjad.string.to_shout_case("scale degrees 4 and 5")
'SCALE_DEGREES_4_AND_5'
>>> abjad.string.to_shout_case("scale_degrees_4_and_5")
'SCALE_DEGREES_4_AND_5'
>>> abjad.string.to_shout_case("scale-degrees-4-and-5")
'SCALE_DEGREES_4_AND_5'
>>> abjad.string.to_shout_case("ScaleDegrees4And5")
'SCALE_DEGREES_4_AND_5'
abjad.string.to_tridirectional_lilypond_symbol(argument: int | str | None) str | None[source]

Changes argument to tridirectional LilyPond symbol.

>>> abjad.string.to_tridirectional_lilypond_symbol(abjad.UP)
'^'
>>> abjad.string.to_tridirectional_lilypond_symbol(abjad.DOWN)
'_'
>>> abjad.string.to_tridirectional_lilypond_symbol(1)
'^'
>>> abjad.string.to_tridirectional_lilypond_symbol(0)
'-'
>>> abjad.string.to_tridirectional_lilypond_symbol(-1)
'_'
>>> abjad.string.to_tridirectional_lilypond_symbol("^")
'^'
>>> abjad.string.to_tridirectional_lilypond_symbol("-")
'-'
>>> abjad.string.to_tridirectional_lilypond_symbol("_")
'_'

Returns none when argument is none:

>>> abjad.string.to_tridirectional_lilypond_symbol(None) is None
True
abjad.string.to_tridirectional_ordinal_constant(argument: int | str | None) Vertical | None[source]

Changes argument to tridirectional ordinal constant.

>>> abjad.string.to_tridirectional_ordinal_constant("^")
<Vertical.UP: 1>
>>> abjad.string.to_tridirectional_ordinal_constant("_")
<Vertical.DOWN: -1>
>>> abjad.string.to_tridirectional_ordinal_constant(1)
<Vertical.UP: 1>
>>> abjad.string.to_tridirectional_ordinal_constant(-1)
<Vertical.DOWN: -1>
>>> abjad.string.to_tridirectional_ordinal_constant(abjad.UP)
<Vertical.UP: 1>
>>> abjad.string.to_tridirectional_ordinal_constant(abjad.DOWN)
<Vertical.DOWN: -1>
>>> abjad.string.to_tridirectional_ordinal_constant(abjad.CENTER)
<Vertical.CENTER: 0>
>>> abjad.string.to_tridirectional_ordinal_constant(None) is None
True
abjad.string.to_upper_camel_case(string: str) str[source]

Changes string to upper camel case.

>>> abjad.string.to_upper_camel_case("scale degrees 4 and 5")
'ScaleDegrees4And5'
>>> abjad.string.to_upper_camel_case("scale_degrees_4_and_5")
'ScaleDegrees4And5'
>>> abjad.string.to_upper_camel_case("scale-degrees-4-and-5")
'ScaleDegrees4And5'
>>> abjad.string.to_upper_camel_case("ScaleDegrees4And5")
'ScaleDegrees4And5'