I have couple of files with different date and value formats. Will use a function which will format them correctly...
Source files:
There are 4 files in the folder. Some dates are formatted as DD/MM/YYYY other as MM/DD/YYYY. And also some fields with Amount having " . " other " , " as a decimal indicator.
data:image/s3,"s3://crabby-images/4aa83/4aa83af2320a963c163903f314bf936657a6cde9" alt=""
Step1: I have created a table with Country codes and moved the table into power query. Get one file into power query, use the code to build a function.
data:image/s3,"s3://crabby-images/1a02a/1a02a73899e587a0b0f8dace7aade4dbb4a61039" alt=""
CultureTbl is the table containing a correct culture for each country file I have inside the folder.
fxCulture: I have just imported one file from the folder and I am going to rewrite the code so it will be used as a function to extract the rest of the files.
data:image/s3,"s3://crabby-images/76777/767779e912eafd6925c34287e4f8a53850280a1f" alt=""
Step2: In power query, click on the fxCulture table and open up Advanced Editor. Replace the highlighted part of the code with Table. In the last step : Table.TransformColumnTypes, the 3rd argument is culture as text. So I am using variable Culture for this. You don't have to specify the data types (binary, text) it is optional.
data:image/s3,"s3://crabby-images/994da/994da3e2e2ff1a4b50807f52ce9af6ac64472b6a" alt=""
Step3: the function is ready, I am loading the rest of the files form a folder.
data:image/s3,"s3://crabby-images/3b6de/3b6de818d441ceda7b00492150c3433e70c728ba" alt=""
Step4: Extract text between delimiters to get the country names.
data:image/s3,"s3://crabby-images/667c2/667c2b045c0ee344ee68eb0f6cacc66d5b7997bb" alt=""
Step5: Merge queries as new.
data:image/s3,"s3://crabby-images/30ef7/30ef7457a737e75890466049b12796cdf4b0f9eb" alt=""
Step6: The merge step has created a table. Keep just Culture column.
Step7: Highlight Content, Name, Culture columns and remove other columns.
data:image/s3,"s3://crabby-images/cc5af/cc5aff39470b4989d993968560ce669aac29ed3c" alt=""
Step8: Now it's time to use the function. Go to Add Column> Invoke Custom Function. The variables form the function will look for two columns. I am going to map them to Content (Table variable) and Culture (Culture variable)
data:image/s3,"s3://crabby-images/3cdbe/3cdbed591cb396fbdbdb1df62d99a3387afd4274" alt=""
How you can see form this picture, dates and amounts are coming in a correct format. I am going to remove Content and Culture columns.
data:image/s3,"s3://crabby-images/f690b/f690bf551a539e1c8d126449e9ca17e6c3d30c1d" alt=""
Final table:
data:image/s3,"s3://crabby-images/733f3/733f3c2e263749c712f87738a65ff0482bb41de3" alt=""
Now I can add more files into that folder, refresh the table and all the files will be loaded correctly with no date or value issues.
data:image/s3,"s3://crabby-images/c9b64/c9b64690b778af7fb5d4c2f9cc56ac535175a0f4" alt=""
After refresh:
data:image/s3,"s3://crabby-images/72f41/72f41107cddf16ed7b9e9dcefbf7bf8820726768" alt=""
EXAMPLE_2
Power Query using Default Regional Settings. I have created a table with 3 types of dates and 2 types of values. I will fix the date and value problems with Using Local... option.
DD/MM/YYYY=TEXT(DAY(A2),"00")&"/"&TEXT(MONTH(A2),"00")&"/"&YEAR(A2)
ISO Date=YEAR(A2)&TEXT(MONTH(A2),"00")&TEXT(DAY(A2),"00")
US Sales values are formatted as number and France Sales are formatted as text.
data:image/s3,"s3://crabby-images/98147/98147a24100f8a1e5f8ddb92b6b9f69ffdf11771" alt=""
Step1: Load the table into Power Query. I have US in the Regional Settings and just the first date format was detected correctly. If I would change my Regional Settings to United Kingdom, both MM/DD/YYYY and DD/MM/YYYY will be detected correctly because United Kingdom Regional Settings can do more magic then US settings. But I am not going to prove this I just show you how to fix this problem with dates and values for sales.
data:image/s3,"s3://crabby-images/8ebc3/8ebc37de83c987c2dd438b5e9ae22504df1bee29" alt=""
Step2: click on the data type > Using Locale
Step3: choose data type Date, Locale: United Kingdom or France...(what works)
data:image/s3,"s3://crabby-images/ace24/ace24164a4ee160115489745a2359b0af746742b" alt=""
Step4: ISO Date: If is formatted as number change it to text first and then from text to date.
data:image/s3,"s3://crabby-images/de29c/de29cec1f96920a6865be0d825432a081d945478" alt=""
Step5: France Sales col. is formatted as text. If I change the data type to decimal it returns an error. You can fix it by Using Local...
data:image/s3,"s3://crabby-images/97a4d/97a4d1c4a61eb6a60af23f2e2397da7872513b1c" alt=""
Final table:
data:image/s3,"s3://crabby-images/7bb64/7bb64bd7267f981f6c921531c9f8030834f370cc" alt=""
M Code:
let
Source = Excel.CurrentWorkbook(){[Name="FactSales"]}[Content],
#"Changed Type" = Table.TransformColumnTypes(Source,{{" MM/DD/YYYY", type date}}),
#"Changed Type with Locale" = Table.TransformColumnTypes(#"Changed Type", {{"DD/MM/YYYY", type date}}, "en-GB"),
#"Changed Type1" = Table.TransformColumnTypes(#"Changed Type with Locale",{{"ISO Date", type date}, {"US Sales", type number}}),
#"Changed Type with Locale1" = Table.TransformColumnTypes(#"Changed Type1", {{"France Sales", type number}}, "fr-FR")
in
#"Changed Type with Locale1"
Comments