Sheerpower Logo
F.6  SPRINTF String Formatting
string$ = SPRINTF(string_format$, arg1, arg2, .. )
The name stands for "String Print-Formatted". The function name was chosen to match the name of similar functions found in programming languages such as C, C++, Java, Javascript, PYTHON, etc. Unlike other implimentations, the sheerpower SPRINTF() function is highly optimized and very fast.

Given the formatting string and a list of optional arguments, returns the string result of the arguments applied to the format. The arguments can be of any data type.

Simple Formatting Examples
Each % within the formatting string marks where the content of the additional arguments are substituted into the string. Each % marks the beginning of a format and is followed by an optional letter and other specifications.

Simple Substitution
age = 33 print sprintf('Age is %', age) Age is 33 name$ = 'Sally Sue' age = 22 note$ = sprintf ('% is %', name$, age) print 'Here is my note: '; note$ Here is my note: Sally Sue is 22

Real and integer Formatting
In sheerpower, the r and i formats are used for numeric values, representing Real and Integer types, respectively. For compatibility with other implementations of sprintf, the f format can also be used for Real numbers, and the d format can also be used for Integer numbers.
print sprintf('PI is about %r', pi) print sprintf('PI is about %i', pi) PI is about 3.1415926535897932 PI is about 3
Using a .n after the %, we can specify the number (.n) of decimal digits. This also rounds the number. For example, we might want to show a real rounded to three decimal digits:
print sprintf('PI is about %.3r', 3.14159265) PI is about 3.142

Singulars and Plurals
One sheerpower specific format is %p, which produces a word in its plural form if needed. The last numeric value that precedes the %p format determines if the word is produced as a singular or plural.
ox_counter = 56 print sprintf('I have % %p.', ox_counter, 'ox') I have 56 oxen. ox_counter = 1 print sprintf('I have % %p.', ox_counter, 'ox') I have 1 ox. print sprintf('%p', 'foot') feet

Dates and times
To format dates and times you use the %t formatter followed by date/time item names. Item names have a @ prefix. The sprintf() argument is the time in seconds as calculated by the seconds() function. If the seconds given is zero, then the current date and time is used.

The date/time item names are:
  • @yyyy -- Four digit year -- 2022
  • @yy -- Two digit year -- 22
  • @month -- Month name -- January
  • @mon -- Short month name -- Jan
  • @mm2 -- Two digit month -- 09
  • @mm -- One or Two digit month -- 9 or 10
  • @dd2 -- Two digit day -- 09
  • @dd -- One or two digit day number -- 9 or 10
  • @h2 -- Two digit hour -- 09
  • @h -- On or two digit hour -- 9 or 10
  • @mt -- Military time -- 14
  • @m2 -- two digit minute -- 09
  • @m -- One or two digit minute -- 9 or 10
  • @s2 -- Two digit seconds -- 09
  • @s -- one or Two digit seconds -- 9 or 10
  • @ampm -- AM or PM indictor
  • @day -- Day of the week -- Monday
  • @mil -- military datetime -- 15-Jun-2022 07:38:10
  • @short -- short length datetime -- Jun09 13:54
If no prefixed item is given, the default of @short is used. If no sprintf() argument is given, the current datetime is used. The formatting of @short is highly optimized. Over 10 million per second can be formatted. This makes it ideal for inclusion into log files.

f$ = "%tThe party is @month (month# @mm) @dd, @yyyy @mt:@m2:@s2 - or @h2:@m2:@s2 @ampm on a @day" now_secs = seconds('') print sprintf(f$, now_secs) The party is June (month# 6) 10, 2022 05:32:28 - or 05:32:28 AM on a Monday f$ = '%t@month @dd2-@mon-@yyyy' now_secs = seconds('20221225 0000') print sprintf(f$, now_secs) December 25-Dec-2022 print sprintf(%t@mil Processing starting') 15-Jun-2022 08:26:47 Processing starting print sprintf(%t@short Processing starting') Jun09 15:11 Processing starting print sprintf('%t Processing started') Jun09 15:11 Processing started

Dealing With String Substitutions
Often strings need to be formatted in specific ways. The %z format is used for this purpose. It supports two methods -- each character in turn substitutions using the "@" and segment substitutions using "[]":
ssn$ = '123456789' print sprintf('%z SSN: @@@-@@-@@@@', ssn$) print sprintf('%z SSN: [1:3]-[4:5]-[6:9]', ssn$)
Segments are the most versatile of the two methods. For each segment, specify [aaa:zzz] where aaa is the starting location in the string and zzz is the ending location. Note that the first location is one and the last location is the length of the string. The word "end" stands for the end of the string.

Within the "[]" one can also include the additional formatting options of "uc" or "lc" for uppercasing or lowercasing the segment:
a$='abcdefGHI' print sprintf('%z[uc:1:3]-[4:5]-[lc:6:end]', a$) ABC-de-fghi

Formatting Money and Large Numbers
Another sheerpower specific format is %m, which inserts commas into numbers as needed. It is frequently used when formatting money or large numbers. The .2 in the example below says two decimal digits will be returned. The number will also be rounded as needed.
cash = 1234567.887 print sprintf('About $ %.2m', cash) About $ 1,234,567.89

Positioning with Horizontal Tabs
sheerpower also supports a horizontal tab format using %h. The argument value is the tab position. Tab position one is the first position.
tab_pos = 15 age = 45 print sprintf('The age was: %h%i',tab_pos, age) The age was: 45

Column Alignment
Column alignment is accomplished by specifying the fixed width of a given number or string. The width is specified by supplying a number directly after the %. For example, to give a fixed width of 10 characters:
print sprintf('Number: %10i and more.', 123) Number: 123 and more.
By default, numbers are right-justified within columns. To left-justify a number, give a negative column width:
print sprintf('Number: %-10i and more.', 123) Number: 123 and more.

Octal, Hexadecimal, and Binary
The %o, %x, and %b are used to format numbers into octal, hexadecimal, and binary.
print sprintf('%i in Octal: %o Hex: %x Binary: %b', 123, 123, 123, 123) 123 in Octal: 173 Hex: 7b Binary: 1111011

Embedding Special Characters
Sometimes there is a need to embed special characters into the format. The "\" (back-slash) is used for this purpose. For example, to insert a "new line" character into the format use \n. For example:
print sprintf ('Hello\nWorld') Hello World

Below is the full list of special characters:
CombinationResult
\bBackspace
\fForm-feed
\nNew line
\rReturn
\tTab
\0nnnGenerate a character based
on the octal value
of nnn
For example \0102 >> B
\\The "\" character
print sprintf ('The letter (\0102)') The letter (B)

Note: The SPRINTF function has many other formatting options. For details, see the "PRINTF Parameters" section here.
The %h, %m, %p, %t, and %z formats are sheerpower specific.


SPRINTF() and Program Safety
sheerpower's implementation of SPRINTF() is completely safe. If a wrong data type is passed, sheerpower will attenpt to coerce it to the correct data type. If this cannot be done, an exception is raised, explaining the problem. If too few or too many arguments are passed, an exception is raised. In no case will the sheerpower runtime environment crash when processing the SPRINTF() function.
Hide Description

    

       


      

Enter or modify the code below, and then click on RUN

Looking for the full power of Sheerpower?
Check out the Sheerpower website. Free to download. Free to use.
Wide screen