@formula прошу проверить))

PeNgViN213

Well-Known Member
01.07.2017
46
0
#1
Добрый день коллеги, очень прошу вас проверить правильно ли я написал формула, для следующего задания:
Cделать колонку с иконкой восклицательного красного знака.
Данный знак должен отображаться только для тех документов, у которых не заполнены одно или более полей из списка.

Код:
@If(@Contains(badkind;" ");0;150 & @Contains(badtype;" ");0;150 & @Contains(badprod;" ");0;150 & @Contains(badmodel;" ");0;150 & @Contains(snerr;" ");0;150)
 

alexas1

Well-Known Member
Lotus team
10.04.2014
704
242
#2
listfields := Field1:Field2:Field3:Field4:Field5; "имена контролируемых полей";
n :=5"; "кол-во полей";
image := "восклзнак.png"; "или у тебя 150, вроде";
@if(@elements(@trim(listfields)) < n ; image ; "")
вроде так
 

PeNgViN213

Well-Known Member
01.07.2017
46
0
#3
listfields := Field1:Field2:Field3:Field4:Field5; "имена контролируемых полей";
n :=5"; "кол-во полей";
image := "восклзнак.png"; "или у тебя 150, вроде";
@if(@elements(@trim(listfields)) < n ; image ; "")
вроде так
По-моему везде показывает, даже где заполнено, надо же где пусто
 
Последнее редактирование:

alexas1

Well-Known Member
Lotus team
10.04.2014
704
242
#4
По-моему везде показывает, даже где заполнено, надо же где пусто
не может быть, правда тут n :=5" лишняя ковычка (ты же исправил?)
... или в полях есть чота не то, кроме "не заполнено", пробелы, например
-----
хотя нет, и с пробелами тут все ОК.
в общем, должно работать сто пудов. ищи, где сам облажался
 

PeNgViN213

Well-Known Member
01.07.2017
46
0
#5
не может быть, правда тут n :=5" лишняя ковычка (ты же исправил?)
... или в полях есть чота не то, кроме "не заполнено", пробелы, например
-----
хотя нет, и с пробелами тут все ОК.
в общем, должно работать сто пудов. ищи, где сам облажался
в полях должно быть пусто, тогда должен появляться знак
 

alexas1

Well-Known Member
Lotus team
10.04.2014
704
242
#7
??? кавычки с пробелами штоля ???
если 1 или больше "просто пробелов" - даст пустой элемент массива, трим его уберёт нафик))))
должно работать;)
кста, сам себе не поверил, проверил - работает))))
 

PeNgViN213

Well-Known Member
01.07.2017
46
0
#8
??? кавычки с пробелами штоля ???
если 1 или больше "просто пробелов" - даст пустой элемент массива, трим его уберёт нафик))))
должно работать;)
кста, сам себе не поверил, проверил - работает))))
нет, если поле - пустое, не заполнено
 

Gandliar

Well-Known Member
Lotus team
16.02.2004
328
6
#19
Тут видимо подойдет, что то вроде
@if(
form="form1" & @elements(@trim(field1:field2))<2; 150;
form="form2" & @elements(@trim(field2:field3:field4))<3; 150;
"");

так как судя по всему в разных доках разный набор полей.

или

@if(
form="form1" & (@trim(field1)="" | @trim(field2)=""); 150;
form="form2" & (@trim(field3)="" | @trim(field4)="" | @trim(field5)=""); 150;
"");
 

lmike

нет, пердело совершенство
Lotus team
27.08.2008
6 484
360
#20
ну а какие еще операциями можно проверить на пустоту?
поле не заполняли: @IsAvailable(field)
поле пустое - выше писали, но я бы еще и @Trim сделал
проверка синхронности списков - это отдельная тема, список надо еще "дополнять" и "фильтровать", все сильно зависит от контекста, перемножение списков как пример (кусок из кода)
Код:
snum:=@Explode("0 1 2 3 4 5 6 7 8  9";" ");
res:=@If(@IsError(v);@ThisName;v);
n:=@Elements(res);
num:=@Subset(@TextToNumber(snum *+ snum);n);