Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Join us at FabCon Atlanta from March 16 - 20, 2026, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM. Register now.

Reply
DonPepe
Helper II
Helper II

Convert List in Function

Hi, 

 

My goal is to get all the working date for a service from a given Start date and a given End date knowing that I know only the day of week and the service validity. 

Parameters :  

  • Start date = 21/6/2022
  • End date = 15/7/2022

Data :

Service ID Service_FREQUENCYDAY_IN_WEEKService validity start dateService validity end date
SDF12321234212-06-2231-12-25

So the service SDF1232 work from Monday (frequency 1) to Thursday (Frequency 4) and here I have the record of Thuesday (frequency 2 = day in week 2) his validity is from 12-06-22 to 31-12-25.

 

Basicaly, here, I want all the Thuesday between Start date 21/6/2022 and end date 15/7/2022 since the two parameters are included into the service validity date. 

 

The think to choose the range between the parameters or the service validity is ok. 

Where I strugle is how can I get the list of each Thursday. 

 

I tried like this but I have an error that Power Query cannot convers list type to function type and I dont know how to resolve it.

 

let
   Source = RawFlexiView, 
   ListDayWeek = Table.AddColumn(
      Source, 
      "Date", 
      List.Select(
         {Number.From(Date.FromText(StartDate)) .. Number.From(Date.FromText(EndDate))}, 
         each Date.DayOfWeek(
            _, 
            Lines.ToText(
               List.First(
                  List.Range(
                     {
                        Day.Sunday, 
                        Day.Monday, 
                        Day.Tuesday, 
                        Day.Wednesday, 
                        Day.Thursday, 
                        Day.Friday, 
                        Day.Saturday
                     }, 
                     Number.From([PLAOSP Start Day In Week]), 
                     1
                  )
               )
            )
         )
            = 0
      )
   )
in
   ListDayWeek

 

If I dont use the right strategy tel me also, I am quite new on Power Query.  

 

 Thanks a lot for your help,

 

Don 

1 ACCEPTED SOLUTION

Use this

Table.AddColumn(
   Source, 
   "DateList", 
   each List.Select(
      List.Dates(
         Date.FromText(StartDate), 
         Duration.Days(Date.FromText(EndDate) - Date.FromText(StartDate)) + 1, 
         #duration(1, 0, 0, 0)
      ), 
      (x)=> Date.DayOfWeek(x) = Number.From([DAY_IN_WEEK])
   )
)

View solution in original post

7 REPLIES 7
KT_Bsmart2gethe
Impactful Individual
Impactful Individual

Hi @DonPepe ,

 

Highlighted in blue is the day of the week.

 

List.Transform(List.Select({Number.From(StartDate)..Number.From(EndDate)}, each Date.DayOfWeek(Date.From(_))+1=2), each Date.From(_))

 

Regards

KT

DonPepe
Helper II
Helper II

Hi @Vijay_A_Verma,

 

Thanks a lot for your answer, it's ok for this example. I just include it in a new column. 

Table.AddColumn(
   Source, 
   "DateList", 
   each List.Select(
      List.Dates(
         Date.FromText(StartDate), 
         Duration.Days(Date.FromText(EndDate) - Date.FromText(StartDate)) + 1, 
         #duration(1, 0, 0, 0)
      ), 
      each Date.DayOfWeek(_) = 2
   )
)

 

Now I would like to have the same result but for any kind of value in the field "DAY_IN_WEEK" 

I tried this but I have an error :

Table.AddColumn(
   Source, 
   "DateList", 
   each List.Select(
      List.Dates(
         Date.FromText(StartDate), 
         Duration.Days(Date.FromText(EndDate) - Date.FromText(StartDate)) + 1, 
         #duration(1, 0, 0, 0)
      ), 
      each Date.DayOfWeek(_) = Number.From([DAY_IN_WEEK])
   )
)

 

the error :

"Sorry... We couldn't apply field access to the Date type.
Details :
Value=05-11-23
Key=PLAOSP Start Day In Week"

 

Thanks a lot,

 

Don 

Can you paste your complete code as the error is not coming from this line? The error is referrring to PLAOSP Start Day In Week field which is not being used in this line. 

Yeah sorry, PLAOSP Start Day In Week is the name of the field, I simplified it by "DAY_IN_WEEK" in this example.

Use this

Table.AddColumn(
   Source, 
   "DateList", 
   each List.Select(
      List.Dates(
         Date.FromText(StartDate), 
         Duration.Days(Date.FromText(EndDate) - Date.FromText(StartDate)) + 1, 
         #duration(1, 0, 0, 0)
      ), 
      (x)=> Date.DayOfWeek(x) = Number.From([DAY_IN_WEEK])
   )
)

Woah, so nice, thanks a lot. 

I am not familiar with expression like this

(x)=> Date.DayOfWeek(x)

 I will try to study more on that 🙂 

Have an excellent day ! 

Vijay_A_Verma
Super User
Super User

Use below to generate a list of Tuesday. Fit this in your code

= List.Select(List.Dates([StartDate],Duration.Days([EndDate]-[StartDate])+1,#duration(1,0,0,0)), each Date.DayOfWeek(_)=2)

Helpful resources

Announcements
October Power BI Update Carousel

Power BI Monthly Update - October 2025

Check out the October 2025 Power BI update to learn about new features.

FabCon Atlanta 2026 carousel

FabCon Atlanta 2026

Join us at FabCon Atlanta, March 16-20, for the ultimate Fabric, Power BI, AI and SQL community-led event. Save $200 with code FABCOMM.

Top Kudoed Authors