Quicken QIF files to Power Query

rasinc

Board Regular
Joined
Jun 28, 2011
Messages
131
I have a client wanting a spreadsheet that can take a quicken qif export file from their investment account and analyse it in Excel. I asked about Power BI and they are looking into it but right now just in Excel for more extensive graphing.

I can import the file and see the data, etc. Each row in the file is identified by a single character that indicates the type of data (eg. Y = Name of Company/Investment, D = date, N = Transaction Type).

Each transaction record can span 4-8 rows or so. Each record is ended with a ^ as the only character on the line.

For an initial step I have promoted the !Type:Invst row to a column header and split the first character off into it's own column.

I would like to take the initial character column and somehow pivot those into column headers. Ideally with each series of rows that make up one record will show up as one row under the proper columns. Not all column headers are in each record.

I tried to use the code from *AlienSX and alansidman in the post here but this code appears to assume the same number of rows for each record and instead of putting null in when column data doesn't exist, it combines the rows from records below with those above when they are missing.

QIF Data will look something like:
!Type:Invst
D12/14' 9 - note this is Dec 14, 2009
NBuy
YRoyal Bank
I124.55 - unit price
Q10
U1255.45
T1255.45
O9.95
^
D2/ 9'21
NContribX
U6,000.00
T6,000.00
M2021 Contribution
L[Savings]
$6,000.00
^
D2/15'24
NDiv
YRoyal Bank
U48.14
T48.14
^

for three records. After the ^, it just starts at the D row again.
The D, N, Y, I Q, U, T, and O should be the column headers and any others that show up in other records. The are in their own column right now. Occasionally I see an M for Memo and L row but not in all records (see middle transaction above).

Can anyone point me in the right direction? I was going to look at using VBA to parse the data but thought I would try Power Query first because I am trying to learn how to use it properly. Right now I only have one sample file of about 6000 records for about 10 years in one investment account but I am told there are 20 years of data he is looking at using from about 8 different accounts.

TIA rasinc
 

Excel Facts

Did you know Excel offers Filter by Selection?
Add the AutoFilter icon to the Quick Access Toolbar. Select a cell containing Apple, click AutoFilter, and you will get all rows with Apple
Would you repost your sample data using XL2BB so that the formatting is known correctly and we don't have to reenter the data and guess at the formatting. Also, then for the three records, mock up how you would like the data shown after cleansing.
 
Upvote 0
If this is what you expect your data to look like then
Book1
ABCDEFGHIJKLMN
1!Type:InvstIndexDNYIQUTOML$
2D12/14' 9112/14' 9BuyRoyal Bank124.55 - unit price101255.451255.459.952021 Contribution[Savings]6000
3NBuy22/ 9'21ContribXRoyal Bank6,000.006,000.00
4YRoyal Bank32/15'24Div48.1448.14
5I124.55 - unit price
6Q10
7U1255.45
8T1255.45
9O9.95
10^
11D2/ 9'21
12NContribX
13U6,000.00
14T6,000.00
15M2021 Contribution
16L[Savings]
17$6000
18^
19D2/15'24
20NDiv
21YRoyal Bank
22U48.14
23T48.14
24^
Sheet1


Power Query Mcode

Power Query:
let
    Source = Excel.CurrentWorkbook(){[Name="Table1"]}[Content],
    #"Filtered Rows" = Table.SelectRows(Source, each ([#"!Type:Invst"] <> "^")),
    #"Split Column by Position" = Table.SplitColumn(#"Filtered Rows", "!Type:Invst", Splitter.SplitTextByPositions({0, 1}, false), {"!Type:Invst.1", "!Type:Invst.2"}),
    #"Grouped Rows" = Table.Group(#"Split Column by Position", {"!Type:Invst.1"}, {{"Count", each _, type table [#"!Type:Invst.1"=nullable text, #"!Type:Invst.2"=nullable text]}}),
    #"Added Custom" = Table.AddColumn(#"Grouped Rows", "Custom", each Table.AddIndexColumn([Count],"Index",1,1)),
    #"Removed Columns" = Table.RemoveColumns(#"Added Custom",{"Count"}),
    #"Expanded Custom" = Table.ExpandTableColumn(#"Removed Columns", "Custom", {"!Type:Invst.2", "Index"}, {"!Type:Invst.2", "Index"}),
    #"Pivoted Column" = Table.Pivot(#"Expanded Custom", List.Distinct(#"Expanded Custom"[#"!Type:Invst.1"]), "!Type:Invst.1", "!Type:Invst.2")
in
    #"Pivoted Column"
 
Upvote 0
I see an error in my output. Will try again, but I think I am close.
 
Upvote 0
I think I have it now

Power Query:
let
    Source = Excel.CurrentWorkbook(){[Name="Table1"]}[Content],
    #"Filtered Rows" = Table.SelectRows(Source, each ([#"!Type:Invst"] <> "^")),
    #"Split Column by Position" = Table.SplitColumn(#"Filtered Rows", "!Type:Invst", Splitter.SplitTextByPositions({0, 1}, false), {"!Type:Invst.1", "!Type:Invst.2"}),
    #"Added Custom" = Table.AddColumn(#"Split Column by Position", "Date", each if Text.Contains([#"!Type:Invst.2"],"/") then [#"!Type:Invst.2"] else null),
    #"Filled Down" = Table.FillDown(#"Added Custom",{"Date"}),
    #"Grouped Rows" = Table.Group(#"Filled Down", {"Date"}, {{"Count", each _, type table [#"!Type:Invst.1"=nullable text, #"!Type:Invst.2"=nullable text, Date=text]}}),
    #"Added Custom1" = Table.AddColumn(#"Grouped Rows", "Custom", each Table.AddIndexColumn([Count],"Index", 1,1)),
    #"Removed Columns" = Table.RemoveColumns(#"Added Custom1",{"Count", "Date"}),
    #"Expanded Custom" = Table.ExpandTableColumn(#"Removed Columns", "Custom", {"!Type:Invst.1", "!Type:Invst.2", "Date", "Index"}, {"!Type:Invst.1", "!Type:Invst.2", "Date", "Index"}),
    #"Removed Columns1" = Table.RemoveColumns(#"Expanded Custom",{"Index"}),
    #"Pivoted Column" = Table.Pivot(#"Removed Columns1", List.Distinct(#"Removed Columns1"[#"!Type:Invst.1"]), "!Type:Invst.1", "!Type:Invst.2")
in
    #"Pivoted Column"

Book1 (version 1).xlsb
CDEFGHIJKLMN
1DateDNYIQUTOML$
212/14' 912/14' 9BuyRoyal Bank124.55 - unit price101255.451255.459.95
32/ 9'212/ 9'21ContribX6,000.006,000.002021 Contribution[Savings]6000
42/15'242/15'24DivRoyal Bank48.1448.14
Sheet1
 
Upvote 0
Thanks for the quick reply on the weekend. I'll try and figure out how to install the XL2BB. I tried a couple of years ago and it didn't install properly or I couldn't use it properly.

The sample I posted was just from Notepad not Excel. The note about unit price was supposed to be just for me, I should not have included it but it should not cause problems with the transformation if that column stays as text.

You are correct, there is still an issue. I just tried your code and it is pulling in data to the first row from other rows further down because of the discrepancy in fields per record.

I think it is the Grouped Rows step that is causing the problem here. Filtering out the ^ removed the flag on where a record ends.

Is there any way to add a pseudo Index column that starts at the top of the file and assigns 1 to each row until it his ^, then increments to 2 until the next ^. Then that index column specifies what is part of one record and it might be used after for grouping on the ultimate column header.
 
Upvote 0
Sorry there is still a problem. Let me look at it some more and I will try and provide some more data. I can't just post the full file because of confidentiality. There are some identifying data in it all over the place, so I have to pull and remove references to the owner. Thank you for your efforts so far.

One question, are any of the stops you posted, manually written or are they all created by the ribbon tools?
 
Upvote 0
All were in the UI. Wrote code in the Add Column functions of the UI. They are fairly straight forward though.
 
Upvote 0
Thanks. I can add a conditional column that adds something when the first column = "D". If I could get that to increment from 1 and up each time a D is encountered, then I could just fill down and get a record number for each full record, regardless of the number of columns in each record. I tried to add an index column that starts with 1 but haven't been able to embed that in an If statement yet.

Then I just have to figure out how to use it to combine everything.
 
Upvote 0

Forum statistics

Threads
1,224,830
Messages
6,181,227
Members
453,025
Latest member
Hannah_Pham93

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top