1

我有一个有两列的表:1.月 2.周

表中数据如下:

月 | 星期

1 | 4

2 | 3

3 | 2

4 | 1

5 | 4

6 | 3

7 | 2

8 | 1

9 | 4

10 | 3

11 | 2

12 | 1

现在,根据用户提供的日期,我需要根据上表中的映射找到相应的一周中的第一天。

示例 1

来自用户的日期:2019 年 9 月 29 日

现在,我将在用户提供的日期中查看月份,然后基于该月份;我将查看表格并查看该月的相应周。在这里,对于第 9 个月(九月),相应的一周将是第 4 周。现在,因为我有那个月的一周;我需要在一年中的那个月份找到那一周的第一个日期。在这种情况下,它将是 2019 年 9 月 23 日。

我的解决方案应该是 2019 年 9 月 23 日。

示例 2

来自用户的日期:2019 年 10 月 10 日

现在,我将在用户提供的日期中查看月份,然后基于该月份;我将查看表格并查看该月的相应周。在这里,对于第 10 个月(10 月),相应的一周将是第 3 周。现在,因为我有那个月的一周;我需要在一年中的那个月份找到那一周的第一个日期。在这种情况下,它将是 2019 年 10 月 21 日。

我的解决方案应该是 2019 年 10 月 21 日。

我正在尝试为这种情况提出 PowerApps 公式。任何帮助将不胜感激。

4

1 回答 1

0

根据您的要求,您应该能够使用此表达式(假设用户的日期来自日期选择器;如果日期来自其他来源,您需要调整表达式):

With(
    { firstDay: Date(Year(DatePicker1.SelectedDate), Month(DatePicker1.SelectedDate), 1) },
    With(
        {
            firstMonday: DateAdd(firstDay, 7 - Weekday(firstDay, StartOfWeek.Tuesday), Days),
            weekNumber: LookUp(MyTable, Month = Month(DatePicker1.SelectedDate), Week)
        },
        DateAdd(firstMonday, 7 * (weekNumber - 1), Days)))

让我们分解一下:

  • 第一个With创建一个名为的范围变量firstDay,它保存用户选择的月份的第一天;
  • 第二个With计算每月的第一个星期一,因为这决定了方案中的周数。它通过将距下周一的天数添加到该月的第一天来实现这一点,这是在上述步骤中计算的。它还从您的表中检索周数(在我的示例中,我将其称为“MyTable”,您可以在场景中将其替换为适当的名称)
  • 最后,给定周数和每月的第一个星期一,我们可以添加适当的天数以获得所需的结果。

希望这可以帮助!

于 2019-10-01T17:57:43.450 回答