Создайте новый столбец и отобразите его в числовых значениях - PullRequest
0 голосов
/ 25 сентября 2018

У меня есть 1 файл со следующими столбцами: Дата документа и Дата утилизации .

В Power BI Desktop я хотел бы создать еще один столбец с именем ' Длительность ', который можно рассчитать, взяв Дата утилизации - Дата документа и я хочу, чтобы новый столбец отображался в числовых значениях, поскольку Дата утилизации & Дата документа либо в серийный номер (например: 39448), либо дата (пример: 25.09.2008) формат.

Есть ли код или что-то для этого?Спасибо!

Ответы [ 2 ]

0 голосов
/ 26 сентября 2018

Сначала создайте два новых столбца даты для документа и расположения, поскольку в типе данных есть некоторые отклонения.Я просто проверяю, есть ли после преобразования в поле даты символ «/», означающий, что это тип даты, если нет, я предполагаю, что он сериализован и будет преобразован.Следующий DAX должен сделать это, НО это не проверено, поэтому попробуйте.

True Document Date :=
SWITCH (
    TRUE (),
    AND (
        ISERROR ( SEARCH ( "/", FORMAT ( [Document], "text" ) ) ),
        [Document] >= 32767
    ), FORMAT ( DATE ( 2000, 1, [Document] - 36523 ), "YYYY-MM-DD" ),
    AND (
        ISERROR ( SEARCH ( "/", FORMAT ( [Document], "text" ) ) ),
        [Document] < 32767
    ), FORMAT ( DATE ( 1900, 1, Sheet1[DATE SERIAL NUMBER] ), "YYYY-MM-DD" ),
    NOT ( ISERROR ( SEARCH ( "/", FORMAT ( [Document], "text" ) ) ) ), [Document]
)

True Disposition Date :=
SWITCH (
    TRUE (),
    AND (
        ISERROR ( SEARCH ( "/", FORMAT ( [Disposition], "text" ) ) ),
        [Disposition] >= 32767
    ), FORMAT ( DATE ( 2000, 1, [Disposition] - 36523 ), "YYYY-MM-DD" ),
    AND (
        ISERROR ( SEARCH ( "/", FORMAT ( [Disposition], "text" ) ) ),
        [Disposition] < 32767
    ), FORMAT ( DATE ( 1900, 1, Sheet1[DATE SERIAL NUMBER] ), "YYYY-MM-DD" ),
    NOT ( ISERROR ( SEARCH ( "/", FORMAT ( [Disposition], "text" ) ) ) ), [Disposition]
)

Затем просто возьмите разницу в днях и сохраните результаты в новом вычисленном столбце:

Date Delta :=
DATEDIFF ( [True Document Date], [True Disposition Date], DAY )
0 голосов
/ 25 сентября 2018

Возможно, я здесь упускаю точку, но если у вас есть такой набор данных:

Document    Disposition
25.09.2018  22.09.2018
24.09.2018  21.09.2018
23.09.2018  20.09.2018
22.09.2018  19.09.2018
21.09.2018  18.09.2018
20.09.2018  17.09.2018
19.09.2018  16.09.2018
18.09.2018  14.09.2018
17.09.2018  13.09.2018
16.09.2018  12.09.2018
15.09.2018  11.09.2018
14.09.2018  10.09.2018
13.09.2018  09.09.2018
12.09.2018  08.09.2018
11.09.2018  07.09.2018
10.09.2018  06.09.2018
09.09.2018  05.09.2018
08.09.2018  04.09.2018

Затем вы можете загрузить их с помощью Get Data, перейти к Edit Queries, выбрать Add Columnи просто установите его следующим образом:

enter image description here

Затем вы можете щелкнуть значок ABC / 123 enter image description here сверхустолбца и измените тип данных на Whole number, и вы получите это:

enter image description here

Пожалуйста, дайте мне знать, если это не то, что выискали.

...