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

Don't miss out! 2025 Microsoft Fabric Community Conference, March 31 - April 2, Las Vegas, Nevada. Use code MSCUST for a $150 discount. Prices go up February 11th. Register now.

Reply
Jo74
New Member

Powerquery add column If date in another column is more than a year ago

Hi all

I am fairly new to Power Query and need some help please.  I have a column with a created date and if it is more than a year old the calculation is based on another column.

 

So If created date is older than 1 year the new column should be value column *  0.5 otherwise it should just be the value.  Is this possible?

example

Created DateValueNew Column
20/12/20236500032500
15/7/20241000010000

 

Any suggestions greatly appreciated.

 

Kind regards 

Jo

8 REPLIES 8
v-nmadadi-msft
Community Support
Community Support

Hi @Jo74 ,

I wanted to check if you had the opportunity to review the information provided. Please feel free to contact us if you have any further questions. If my response has addressed your query, please accept it as a solution and give a 'Kudos' so other members can easily find it.
Thank you.

v-nmadadi-msft
Community Support
Community Support

Hi @Jo74 ,

May I ask if you have resolved this issue? If so, please mark the helpful reply and accept it as the solution. This will be helpful for other community members who have similar problems to solve it faster.

Thank you.

Omid_Motamedise
Super User
Super User

Hi @Jo74 , and thanks @OwenAuger .

Use this formula

 

let
    Source = Table.FromRows(Json.Document(Binary.Decompress(Binary.FromText("i45WMjLQNzTSNzIwMlbSUTIzNTAwUIrViVYyNNU3B4maAEUNDcCisQA=", BinaryEncoding.Base64), Compression.Deflate)), let _t = ((type nullable text) meta [Serialized.Text = true]) in type table [#"Created Date" = _t, Value = _t]),
    #"Changed Type" = Table.TransformColumnTypes(Source,{{"Created Date", type date}, {"Value", Int64.Type}}),
    #"Added Custom" = Table.AddColumn(#"Changed Type", "Custom", each if [Created Date]<Date.From(DateTime.LocalNow()-Duration.From(365)) then 0.5*[Value] else [Value])
in
    #"Added Custom"

 

v-nmadadi-msft
Community Support
Community Support

Hi @Jo74 ,

That is something that can be done using Microsoft Power Query  Formula language(informally called as M language).
Follow this documentation to learn more about M query
Power Query M formula language reference - PowerQuery M | Microsoft Learn

As mentioned by @OwenAuger, the provided M query will help you in creating a new column that you want.

Please reach out to us if you have any further quries related to the provided M query or in power query in general
Dont forget to mark the helpful solution so as to help other community members

If my response(s) assisted you in any way, don't forget to give "Kudos"

Thanks and Regards



Thank you for your help.  I did not manage to get it to work and have just added a simple column after the powerquery in Excel.  Afraid this is outside my realm of understanding!

OwenAuger
Super User
Super User

Hi @Jo74 

I would propose something like this:

let
  Source = #table(
    type table [Created Date = date, Value = number],
    {
        {#date(2023, 12, 20), 65000},
        {#date(2024, 07, 15), 10000}
    }
  ),
  DateThreshold = Date.AddYears(Date.From(DateTime.FixedLocalNow()), - 1),
  #"Added New Column" = Table.AddColumn(
    Source,
    "New Column",
    each (if [Created Date] < DateThreshold then 0.5 else 1) * [Value],
    type number
  )
in
  #"Added New Column"

Are you able to get this working in your current query?


Owen Auger
Did I answer your question? Mark my post as a solution!
Blog
Twitter
LinkedIn

Hi Owen

Thank you very much for taking the time to help me with this query - unfortunately not quite right, it is pulling the example figures only and not working the calculation out for each date.  So a whole column of 65000 & 10000.   There are over 125 rows with different dates and amounts.   If the date is older than a year it should multiply the value column by 0.5 and if it is not older than a year it needs to return the value without the multiplication, see below.

Jo74_0-1736539958520.png

Kind regards

Jo

Thanks for trying this Jo.

Just to clarify, my sample M code was intended to illustrate the steps that should be added to the query after the step that produces your existing table.

 

The Source step in my sample should be replaced with whatever steps produced your initial table, then the  Date Threshold and Added New Column steps added after this.

You could add these steps either in the Advanced Editor or by adding steps and entering code in the formula bar.

 

Here is a short recording of how I would apply this starting from the table you just posted, using the formula bar to enter the steps, and I have attached a PBIX with this query:

Add value column.gif

 

 

 

 


Owen Auger
Did I answer your question? Mark my post as a solution!
Blog
Twitter
LinkedIn

Helpful resources

Announcements
Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount!

Jan25PBI_Carousel

Power BI Monthly Update - January 2025

Check out the January 2025 Power BI update to learn about new features in Reporting, Modeling, and Data Connectivity.

December 2024

A Year in Review - December 2024

Find out what content was popular in the Fabric community during 2024.