Пример 4:
? power({1, 2, 3, 4}, 2)
-- {1, 4, 9, 16}
См. также:
log, sqrt
prepend
Синтаксис:
s2 = prepend(s1, x)
Описание:
Присоединяет x к началу ряда s1. Длина s2 будет равна length(s1) + 1.
Комментарии:
Если x атом, эта операция дает то же, что и s2 = x & s1. Если же x ряд, то результат будет иным.
Случай, когда s1 и s2 являются одной и той же переменной, обрабатывается очень эффективно.
Пример 1:
prepend({1,2,3}, {0,0}) -- {{0,0}, 1, 2, 3}
-- Сравните со сцеплением (конкатенацией):
{0,0} & {1,2,3} -- {0, 0, 1, 2, 3}
Пример 2:
s = {}
for i = 1 to 10 do
s = prepend(s, i)
end for
-- s будет равно {10,9,8,7,6,5,4,3,2,1}
См. также:
append, concatenation operator &, sequence-formation operator
pretty_print
Синтаксис:
include misc.e
pretty_print(fn, x, s)
Описание:
Печатает в файле или на устройстве fn объект x, используя скобки { , , , }, отступы и последовательные строки, чтобы показать структуру объекта x в удобном для вас представлении s.
Доступен ряд режимов печати, отличающихся представлением s. Подавайте вместо s {}, если хотите воспользоваться режимом по умолчанию (исходным), или задавайте свой любимый режим в элементах ряда s как указано ниже (в квадратных скобках номер элемента ряда s):
[1] показывать символы ASCII:
* 0: никогда
* 1: вместе с любыми целыми в диапазоне ASCII 32..127 (исходный)
* 2: подобно 1, плюс показывать как "строку", когда все целые ряда находятся в диапазоне ASCII
* 3: подобно 2, но показывать *только* буквы в кавычках, а не числа, для любых целых в диапазоне ASCII, а также символы пробела: \t \r \n
[2] число отступов для каждого уровня вложения ряда - исходный: 2
[3] колонка, в которой начинается печать - исходный: 1
[4] область колонки, где начинается перенос строки - исходный: 78
[5] формат для вывода целых - исходный: "%d"
[6] формат для вывода чисел с плавающей точкой - исходный: "%.10g"
[7] минимальная величина кода для символов ASCII - исходный: 32
[8] максимальная величина кода для символов ASCII - исходный: 127
[9] максимальное число выводимых строк.
Если длина s меньше 8, все незаданные опции до конца ряда будут иметь величины по умолчанию, исходные, т.е. {0, 5} даст "никогда не показывать ASCII", плюс 5-символьный отступ, а все остальные величины будут исходными.
Комментарии:
Отображение начнётся из текущей позиции курсора. Обычно вы ожидаете, что печать начинается в колонке 1, но чтобы так было при вызове pretty_print(), необходимо иметь курсор уже именно в первой колонке. Этого можно добиться, просто выведя символ '\n' перед вызовом pretty_print(). Если вы хотите, чтобы печать началась в другой колонке, вам нужно вызвать position() и задать необходимую величину для режима [3]. Тем самым будет обеспечено вертикальное выравнивание скобок в заданном столбце.
Задавая формат для вывода чисел, целых и с плавающей точкой, можно добавить некоторые украшения, т.е. "(%d)" или "$ %.2f".
Пример 1:
pretty_print(1, "ABC", {})
{65'A',66'B',67'C'}
Пример 2:
pretty_print(1, {{1,2,3}, {4,5,6}}, {})
{
{1,2,3},
{4,5,6}
}
Пример 3:
pretty_print(1, {"Euphoria", "Programming", "Language"}, {2})
{
"Euphoria",
"Programming",
"Language"
}
Пример 4:
puts(1, "word_list = ") -- курсор остановится в колонке 13
pretty_print(1,
{{"Euphoria", 8, 5.3},
{"Programming", 11, -2.9},
{"Language", 8, 9.8}},
{2, 4, 13, 78, "%03d", "%.3f"}) -- первые 6 из 8 подрежимов
word_list = {
{
"Euphoria",
008,
5.300
},
{
"Programming",
011,
-2.900
},
{
"Language",
008,
9.800
}
}
См. также:
?, print, puts, printf
Синтаксис:
print(fn, x)
Описание:
Выводит в файл или на устройство fn объект x со скобками { , , , }, чтобы показать (сохранить) его структуру.
Пример 1:
print(1, "ABC") -- выводится: {65, 66, 67}
puts(1, "ABC") -- выводится: ABC
Пример 2:
print(1, repeat({10,20}, 3))
-- выводится: {{10,20},{10,20},{10,20}}
См. также:
?, pretty_print, puts, printf, get
printf
Синтаксис:
printf(fn, st, x)
Описание: