Solved

Import all worksheets in an excel file then distinct count particular column and append to a table

Posted on 2007-11-20
3
469 Views
Last Modified: 2013-11-27
Hi All,

Purpose: To retreive monthly the total headcount for UK permanent & temp employees only, broken down into Building 1 and Building 2.

I have a headcount spreadsheet that holds the following details in separate worksheets:
permanent employees (perm_emp) - only need three columns to perform calculations "Employee ID", "Building", "Country" (There are 26 columns)
temp employees (temp_emp) - "Employee ID", "Building", "Country"

So far can import the worksheets with the attached code that I have reused from someone elses post (thanks!).

Now I need to:
1) Perform a distinct count on the Employee ID, only where the Employee is from the UK and either Building A or B (A&B are only in the UK).  This is for both Permanents and Temps.
2) Append this figure as 'Total Headcount Building 1' and ''Total Headcount Building 1' to a Results table as the previous months results.  Currently have 3 months data that has been manually entered working on automating all data going in to this database.  So the logic is you would be importing data on the 1st working day of the month for the previous months data.  Is there a way of checking what the last months entry was and then automatically date stamping the data being imported?
e.g                      Date_Created    Total Headcount Building 1   Total Headcount Building 2
                           Jan-07                            1000                                     500
Last Import== >   Feb-07                           1012                                     497
New Import
Auto Date ==>     Mar-07                           1015                                     515
   

3) Deleting the tables Headcount_Import_perm_emp & Headcount_temp_emp.

After any tips, pointers, code for 1 - 3 above.  Am I going about this the right way? (I'm not asking for someone to write the code for me, just pointers to any examples is fine for each section)




Function getXlFile()

Dim objXL As Object, xlSht As Object

Dim strWSname As String

Dim i As Integer, j As Integer

Dim sFile, sTable

    sFile = "\\anetworkshare\test\test.xls"

sTable = "Headcount_Import"
 

Set objXL = CreateObject("Excel.Application")

    objXL.Workbooks.Open sFile, , True

    With objXL

            For i = 1 To .worksheets.Count

                strWSname = .worksheets(i).Name

                Set xlSht = .activeworkbook.worksheets(i)

                'Get header names

                    For j = 1 To xlSht.usedrange.Columns.Count

                       ' Test msg box

                       ' MsgBox xlSht.cells(1, j).Value
 

                    Next
 

            DoCmd.TransferSpreadsheet acImport, acSpreadsheetTypeExcel9, _

                    "" & sTable & "_" & strWSname & "", sFile, True, "" & strWSname & "!"

            Next

            

    End With

    objXL.Quit

    Set objXL = Nothing
 

End Function

Open in new window

0
Comment
Question by:Surferprime
  • 2
3 Comments
 
LVL 119

Expert Comment

by:Rey Obrero
ID: 20321414
create a sub to create the append query  based on the imported worksheet


sub AppendData(strTable as string)
dim sql as string
'build the query
sql="insert into NameOftable(field1,field2... )"
sql=sql & " select distinct  <what ever > 
sql=sql & " from ["& strTable &"]"

currentdb.execute sql

end sub





           DoCmd.TransferSpreadsheet acImport, acSpreadsheetTypeExcel9, _
                    "" & sTable & "_" & strWSname & "", sFile, True, "" & strWSname & "!"
'insert here to call the sub
                     
              call AppendData(stable & "_" & strWSName)

'delete the table
             currentdb.execute "drop table ["& sTable & "_" & strWSname &"]"

Next
0
 

Author Comment

by:Surferprime
ID: 20326700
Hi, thanks for the post, however I'm not sure on a couple of things?
How will this perform a distinct count of the number of employees for both Temps and Perms then add them together?
Also  Is there a way of checking what the last months entry was and then automatically date stamping the data being imported?

Many thanks!
0
 
LVL 119

Accepted Solution

by:
Rey Obrero earned 500 total points
ID: 20326926
<How will this perform a distinct count of the number of employees for both Temps and Perms then add them together?> you have to build the query

<Also  Is there a way of checking what the last months entry was and then automatically date stamping the data being imported?>
you can use dmax("datefield","nameoftable","datefield< date")
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

In the previous article, Using a Critera Form to Filter Records (http://www.experts-exchange.com/A_6069.html), the form was basically a data container storing user input, which queries and other database objects could read. The form had to remain op…
Regardless of which version on MS Access you are using, one of the harder data-entry forms to create is one where most data from previous entries needs to be appended to new records, especially when there are numerous fields and records involved.  W…
Familiarize people with the process of utilizing SQL Server stored procedures from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Micr…
In Microsoft Access, learn how to use Dlookup and other domain aggregate functions and one method of specifying a string value within a string. Specify the first argument, which is the expression to be returned: Specify the second argument, which …

911 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

24 Experts available now in Live!

Get 1:1 Help Now