+ Reply to Thread
Results 1 to 26 of 26

Pulling data from closed CSV file

Hybrid View

  1. #1
    Forum Expert JasperD's Avatar
    Join Date
    05-07-2013
    Location
    Netherlands
    MS-Off Ver
    Excel 2016
    Posts
    1,393

    Pulling data from closed CSV file

    Hi guys and girls,

    I've got a sheet in which I need to look at data that I pull in from a CSV file.
    Now I can pull in all the data into the sheet by just importing the CSV, but it will be hundreds of thousands of rows and to be honest, it makes the file too big and calculating it every time too slow.

    So here's the setup :

    I have around 500 different products - each identified by a PRODUCT_ID
    I want to find out where these products are typically shipped to - that's where the CSV file comes in.
    The CSV contains 6 columns as below (these are the headers) - for each day (DAY, column 1) there is a record of all (AMOUNT, column 6) products (PRODUCT_ID, column 3) that are shipped to a warehouse (WH, column 5).
    DAY, LOC, PRODUCT_ID, PRODUCT_CODE, WH, AMOUNT

    I want to be able to set a date period (for example 1/1/2015 - 1/31/2015) and for each product go through the rows of those dates and find the division of how many are shipped to each warehouse.

    So in the end, I'd like the result to look something like this:
    PRODUCT_ID TIME PERIOD WH AMOUNT % OF TOTAL
    X322-AC 01/01/2015 - 01/31/2015 AMS 458 8.40%
    X322-AC 01/01/2015 - 01/31/2015 BRU 1,118 20.50%
    X322-AC 01/01/2015 - 01/31/2015 … … …
    X322-AC 01/01/2015 - 01/31/2015 … … …

    Now, I know how to do this slowly by importing all the data from the CSV into my sheet, then filtering on the product id, looping through the visible cells and assign each warehouse to a variable, then divide the variables by the total to get the percentage per warehouse.

    But - IDEALLY, I'd like not to have to import the CSV contents at all, but just pull the relevant numbers from the closed file and only show the result.
    Can this be done?

    Name of the CSV will be "shipments.txt" and it's tab delimited.

    Thanks,

    Jasper

  2. #2
    Forum Expert mike7952's Avatar
    Join Date
    12-17-2011
    Location
    Florida
    MS-Off Ver
    Excel 2007, Excel 2016
    Posts
    3,551

    Re: Pulling data from closed CSV file

    Can you upload a example of the csv file and an exaple excel file you want to see for the output? Also any code that you have already, if you do.
    Thanks,
    Mike

    If you are satisfied with the solution(s) provided, please mark your thread as Solved.
    Select Thread Tools-> Mark thread as Solved.

  3. #3
    Registered User
    Join Date
    09-10-2014
    Location
    Matrix
    MS-Off Ver
    2010
    Posts
    70

    Re: Pulling data from closed CSV file

    Ready code for your issue:
    Sub ImportFromCsvTxt()
      Dim FPath As String
      Dim NextFreeFile As Integer
      Dim RowNo As Long
      Dim Sht As Worksheet
      Dim LineFromLine As String
      Dim LineItem() As String
      Dim i As Long
    
      With Application.FileDialog(msoFileDialogFilePicker)
        .AllowMultiSelect = False
        .Title = "Select txt/csv file"
        .Filters.Add "Files CSV/Txt", "*.csv; *.txt", 1
        .FilterIndex = 1
        .Show
          If .SelectedItems.Count <> 0 Then
            FPath = .SelectedItems(1)
          Else
            MsgBox "No file!"
            Exit Sub
          End If
      End With
      
      NextFreeFile = FreeFile
      
      Open FPath For Input As NextFreeFile
      
      Set Sht = ActiveSheet
      RowNo = 1
      
      Do Until EOF(NextFreeFile)
        Line Input #NextFreeFile, LineFromLine
        
        LineFromLine = Replace(LineFromLine, """", "")
        LineItem = Split(LineFromLine, ",")
      
          For i = LBound(LineItem) To UBound(LineItem)
        
            Sht.Cells(RowNo, i + 1) = LineItem(i)
    
          Next i
    
        RowNo = RowNo + 1
    
      Loop
      
      Close NextFreeFile
      
    End Sub
    (*) Reputation points appreciated.
    excelbs.tk

  4. #4
    Forum Expert
    Join Date
    06-25-2009
    Location
    Sofia, Bulgaria, EU
    MS-Off Ver
    Excel 2003-2013
    Posts
    1,290

    Re: Pulling data from closed CSV file

    ADODB, SQL.. etc.
    you know the rest...
    If you are pleased with a member's answer then use the Star icon to rate it.

  5. #5
    Forum Expert JasperD's Avatar
    Join Date
    05-07-2013
    Location
    Netherlands
    MS-Off Ver
    Excel 2016
    Posts
    1,393

    Re: Pulling data from closed CSV file

    @buran : I actually haven't worked with ADODB yet, just a bit, so if you can give me some pointers, then it'd be awesome!
    @michson : fantastic, I'll look at that code later on and will let you know the result!
    @mike : I really wish I could, but it's all pretty sensitive data, so I cannot Sorry!

  6. #6
    Forum Expert
    Join Date
    06-25-2009
    Location
    Sofia, Bulgaria, EU
    MS-Off Ver
    Excel 2003-2013
    Posts
    1,290

    Re: Pulling data from closed CSV file

    Find attached zip.
    it contains the sample.xlsm file, sample.txt you have uploaded, as well schema.ini file that specify that txt file is tab-delimited.
    Note that maybe it's possible to change the sql statement to include the calculation of % of total, but I didn't manage to do so. That's why I use formula to calculate the %.
    If someone else could change the sql to do the calculation I would be curious to see it too.
    Attached Files Attached Files

  7. #7
    Forum Expert
    Join Date
    06-25-2009
    Location
    Sofia, Bulgaria, EU
    MS-Off Ver
    Excel 2003-2013
    Posts
    1,290

    Re: Pulling data from closed CSV file

    Can you upload some sample txt file?
    if data are sensitive, just put few rows of mock data

  8. #8
    Forum Guru Kyle123's Avatar
    Join Date
    03-10-2010
    Location
    Leeds
    MS-Off Ver
    365 Win 11
    Posts
    7,239

    Re: Pulling data from closed CSV file

    You'll need to tweak the query and I suspect that you'll need a schema.ini file, but here's the basics:
    Sub test()
    
        Dim cn As ADODB.Connection
        Dim rs As ADODB.Recordset
        Dim sql As String
    
        Set cn = New ADODB.Connection
        cn.ConnectionString = _
            "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:\MYFILEPATH;Extended Properties='text;HDR=Yes';"
        cn.Open
    
        sql = "Select * FROM " & "[MYFILE.CSV]"
        
        Set rs = cn.Execute(sql)
    
    End Sub
    Last edited by Kyle123; 03-13-2015 at 05:41 AM.

  9. #9
    Forum Expert JasperD's Avatar
    Join Date
    05-07-2013
    Location
    Netherlands
    MS-Off Ver
    Excel 2016
    Posts
    1,393

    Re: Pulling data from closed CSV file

    See attached, hope it is useful!sample.txt

  10. #10
    Forum Expert JasperD's Avatar
    Join Date
    05-07-2013
    Location
    Netherlands
    MS-Off Ver
    Excel 2016
    Posts
    1,393

    Re: Pulling data from closed CSV file

    Hi Kyle,

    awesome, thanks for your reply! I'll check it out and come back if I have any additional questions.
    Thanks,

    Jasper

  11. #11
    Forum Guru Kyle123's Avatar
    Join Date
    03-10-2010
    Location
    Leeds
    MS-Off Ver
    365 Win 11
    Posts
    7,239

    Re: Pulling data from closed CSV file

    Reckon this'll get it:
    Public Sub QueryTextFile()
        Dim rsData As ADODB.Recordset
        Dim sConnect As String
        Dim sSQL As String
        Dim lngLastRow As Long
        Dim strStartDate As String
        Dim strEndDate As String
    
        strStartDate = "01/01/2015"
        strEndDate = "01/31/2015"
    
    
        ' Create the connection string.
        sConnect = "Provider=Microsoft.ACE.OLEDB.12.0;" & _
                   "Data Source=" & ThisWorkbook.Path & "\;" & "Extended Properties=Text;"
        ' Create the SQL statement.
        sSQL = "SELECT PRODUCT_ID,'" & _
               strStartDate & "-" & strEndDate & _
               "', WH, Sum(AMOUNT), SUM(AMOUNT)/(SELECT SUM(AMOUNT) FROM sample.txt WHERE DAY >=#" & strStartDate & "# And DAY<=#" & strEndDate & "#)" & _
               "FROM sample.txt " & _
               "WHERE DAY >=#" & strStartDate & "# And DAY<=#" & strEndDate & "# " & _
               "Group By WH,PRODUCT_ID;"
               Debug.Print
        Set rsData = New ADODB.Recordset
        rsData.Open sSQL, sConnect, adOpenForwardOnly, adLockReadOnly, adCmdText
        ' Check to make sure we received data.
        If Not rsData.EOF Then
            ' Dump the returned data onto Sheet1.
            Range("A1").CopyFromRecordset rsData
    
        Else
            MsgBox "No records returned.", vbCritical
        End If
        ' Clean up our Recordset object.
        rsData.Close
    
    End Sub
    Not the best performance wise (might still be better with formula on a large dataset)

    SQL:
    SELECT product_id, 
           '01/01/2015-01/31/2015', 
           wh, 
           SUM(amount), 
           SUM(amount) / (SELECT SUM(amount) 
                          FROM   sample.txt 
                          WHERE  day >=# 01/01/2015# 
                                 AND day <=# 01/31/2015#) 
    FROM   sample.txt 
    WHERE  day >=# 01/01/2015# 
           AND day <=# 01/31/2015# 
    GROUP  BY wh, 
              product_id;
    Last edited by Kyle123; 03-13-2015 at 06:50 AM.

  12. #12
    Forum Expert JasperD's Avatar
    Join Date
    05-07-2013
    Location
    Netherlands
    MS-Off Ver
    Excel 2016
    Posts
    1,393

    Re: Pulling data from closed CSV file

    Great, thanks a LOT guys!

    Now, to track back for a second on Kyle's original code which pulls everything into the rs dataset.
    Do I have to write the dataset to the sheet or could I work with the dataset saying for example "I have product ID X334-QR, so can I quickly see the division on warehouse sales for this item over the time period" ?
    Cause as I see it now, I'd still have to loop through it per product ID ...?

    Or am I missing something here?

  13. #13
    Forum Expert
    Join Date
    06-25-2009
    Location
    Sofia, Bulgaria, EU
    MS-Off Ver
    Excel 2003-2013
    Posts
    1,290

    Re: Pulling data from closed CSV file

    Quote Originally Posted by JasperD View Post

    I want to be able to set a date period (for example 1/1/2015 - 1/31/2015) and for each product go through the rows of those dates and find the division of how many are shipped to each warehouse.
    my initial understanding was you want the data for all product_ids within the date frame. if you want to see data just for one Product ID, then change the WHERE clause(s) to add also condition on Product_id

  14. #14
    Forum Guru Kyle123's Avatar
    Join Date
    03-10-2010
    Location
    Leeds
    MS-Off Ver
    365 Win 11
    Posts
    7,239

    Re: Pulling data from closed CSV file

    Or am I missing something here?
    Yes, you only select the data you want in the first place

  15. #15
    Forum Expert JasperD's Avatar
    Join Date
    05-07-2013
    Location
    Netherlands
    MS-Off Ver
    Excel 2016
    Posts
    1,393

    Re: Pulling data from closed CSV file

    OK, but opening the data connection takes a bit of time, because the source file is quite large.
    if I only select the data I want in the first place, doing that per product_ID and time frame, will that be instantly after first opening the data connection or do i have close and re-open every time I change the product ID?

    Looking at Buran's code, I feel i'd have to close & reopen every time.
    Looking at Kyle's first code, I open once and then set the dataset based on each product_id

  16. #16
    Forum Guru Kyle123's Avatar
    Join Date
    03-10-2010
    Location
    Leeds
    MS-Off Ver
    365 Win 11
    Posts
    7,239

    Re: Pulling data from closed CSV file

    Then pull all the product codes and filter them in Excel?

    You're still reducing the data since you've summarised by date range

  17. #17
    Forum Expert
    Join Date
    06-25-2009
    Location
    Sofia, Bulgaria, EU
    MS-Off Ver
    Excel 2003-2013
    Posts
    1,290

    Re: Pulling data from closed CSV file

    Quote Originally Posted by JasperD View Post
    IDEALLY, I'd like not to have to import the CSV contents at all, but just pull the relevant numbers from the closed file and only show the result.
    Can this be done?
    I really don't understand what you want - data for one Product ID or data for all?
    If you want for one (or several) you can specify this in the where clause of the sql statement. and then dump all data on worksheet like in the sample or loop trough recordset and do anything you want record by record.
    If you want for all - no need to add anything in the where clause and again you can dump all data on the sheet or loop trogh the recordset and do [anything] with the data record by record.

  18. #18
    Forum Expert JasperD's Avatar
    Join Date
    05-07-2013
    Location
    Netherlands
    MS-Off Ver
    Excel 2016
    Posts
    1,393

    Re: Pulling data from closed CSV file

    First off - I apologize for being unclear.

    On sheet1, there's 500 rows of product IDs.
    For each product ID, I want to know the warehouse division over a certain time period.
    My source txt file contains _all_ product IDs, so I want to narrow it down to just the one product ID on the row I'm looking at at that moment.

    I understand that I can do this by
    1) pulling all the data, filter on the product id and loop through the visible cells.
    2) pulling just the data for the product_id, but then I'll have to pull it 500 times.


    My considerations to see if it can be done in another way are as follows:
    Filtering and looping through (hundreds of) thousands of rows for 500 times will be slow - so ideally, I was hoping I can just pull in a dataset through ADODB and then work with that dataset in memory, which should be infinitely faster than doing it on the worksheet.

    I understand from the previous replies that I cannot do that.

    Can I instead, pull in the data through ADODB to sheet2 and then put that data into an array in memory and just loop through that?
    Or will that be slower than filtering/looping on the sheet (considering that I will have to loop through all records, instead of just the visible ones) ?

    My final aim = minimize time needed to get the data and minimize file size.

    Thanks!

  19. #19
    Forum Expert romperstomper's Avatar
    Join Date
    08-13-2008
    Location
    England
    MS-Off Ver
    365, varying versions/builds
    Posts
    22,173

    Re: Pulling data from closed CSV file

    You can filter a recordset too.
    Everyone who confuses correlation and causation ends up dead.

  20. #20
    Forum Guru Kyle123's Avatar
    Join Date
    03-10-2010
    Location
    Leeds
    MS-Off Ver
    365 Win 11
    Posts
    7,239

    Re: Pulling data from closed CSV file

    I don't understand why you don't just pull it for the 500 you want all at once by passing their IDs in - have a look at the in clause:

    SELECT product_id, 
           '01/01/2015-01/31/2015', 
           wh, 
           SUM(amount)
    FROM   sample.txt 
    WHERE  day >=# 01/01/2015# 
           AND day <=# 01/31/2015# 
           AND product_id in ('X355-DE','X355-DE')
    GROUP  BY wh, 
              product_id;

  21. #21
    Forum Expert JasperD's Avatar
    Join Date
    05-07-2013
    Location
    Netherlands
    MS-Off Ver
    Excel 2016
    Posts
    1,393

    Re: Pulling data from closed CSV file

    romperstomper : that's the answer I was looking for. Now the question is : how
    Kyle: I do that - by importing * it would only have all the shipments from those 500 product_ids - the raw data txt file doesn't contain other product_ids

    For example, if I pull in data set of 01/01/2015 - 02/28/2015 I get just over 30k rows. That's a lot to filter and loop through for 500 times

  22. #22
    Forum Guru Kyle123's Avatar
    Join Date
    03-10-2010
    Location
    Leeds
    MS-Off Ver
    365 Win 11
    Posts
    7,239

    Re: Pulling data from closed CSV file

    There is no looping, did you read my last post?

  23. #23
    Forum Expert JasperD's Avatar
    Join Date
    05-07-2013
    Location
    Netherlands
    MS-Off Ver
    Excel 2016
    Posts
    1,393

    Re: Pulling data from closed CSV file

    Hi Kyle,

    I read your last post.
    Then I read it again and actually understood it combined with the post on the previous page.
    This solution is excellent, thank you so much!
    Problem solved.

    However - just for my future reference, how would I be able to filter on a dataset?
    Thanks,

    Jasper

  24. #24
    Forum Expert romperstomper's Avatar
    Join Date
    08-13-2008
    Location
    England
    MS-Off Ver
    365, varying versions/builds
    Posts
    22,173

    Re: Pulling data from closed CSV file

    It's just:

       rst.Filter = "[FieldName] = 'Criterion'"

  25. #25
    Forum Expert JasperD's Avatar
    Join Date
    05-07-2013
    Location
    Netherlands
    MS-Off Ver
    Excel 2016
    Posts
    1,393

    Re: Pulling data from closed CSV file

    That's very cool, Thanks!!

    Oh and if I try to do 'rst.sort = "WH DESC"' it tells me:
    Run-time error '3251':
    Current provider does not support the necessary interfaces for sorting or filtering


    Which is weird, cause I just filtered
    Is there an easy way to sort like this as well or should I do that on pulling in the data ?

    Thanks again - do you have any easy url for me to read up on all options by any chance?

  26. #26
    Forum Expert romperstomper's Avatar
    Join Date
    08-13-2008
    Location
    England
    MS-Off Ver
    365, varying versions/builds
    Posts
    22,173

    Re: Pulling data from closed CSV file

    Welcome to the weird world of ADO. You need to specify a client side cursor (it will default to server) before you open the recordset, then the Sort will work:
       rst.CursorLocation = adUseClient
    MSDN is a pretty good source for this.

+ Reply to Thread

Thread Information

Users Browsing this Thread

There are currently 1 users browsing this thread. (0 members and 1 guests)

Similar Threads

  1. Data from closed xlsm file without defined file path???
    By dbrizor in forum Excel Programming / VBA / Macros
    Replies: 4
    Last Post: 03-05-2015, 07:27 AM
  2. Copy Data from Closed File to Existing File
    By srikanthbenoni in forum Excel Programming / VBA / Macros
    Replies: 4
    Last Post: 05-21-2012, 08:36 AM
  3. Pulling in data from CSV file with changing file name
    By adelcap in forum Excel Programming / VBA / Macros
    Replies: 24
    Last Post: 04-18-2012, 02:47 PM
  4. Pulling data from closed workbook
    By donyc in forum Excel Programming / VBA / Macros
    Replies: 11
    Last Post: 09-07-2010, 05:58 PM
  5. Replies: 0
    Last Post: 09-22-2009, 04:11 AM

Bookmarks

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts

Search Engine Friendly URLs by vBSEO 3.6.0 RC 1