2010-07-13 33 views
-1

J'ai 2 feuilles Excel (en utilisant Excel 2007)Comment comparer 2 colonne feuille excel valeurs

Excel sheet1 avec les noms de colonnes

name 
kumar 
manu 
kiran 
anu 

Excel sheet2 avec les noms de colonnes

name 
kumar 
anu 

I téléchargera les feuilles puis je clique sur un bouton (ici je comparerai les colonnes nom de chaque feuille), alors je dois ajouter les noms manquants de la feuille 2 à une autre feuille Excel et enregistrez-D: \ names.xlsx

Alors feuille names.xlsx doit contenir

names 
manu 
kiran 

espère que ma question est claire, toute aide serait grande Yaar

+0

désolé - je ne comprends pas vraiment la question - peut-être le formatage de votre question a été perdu ...? – santa

Répondre

1

La meilleure façon de le faire serait de:

  1. lire le fichier Excel dans un datatable en C#
  2. utiliser la fonction de fusion de datatables pour fusionner les colonnes
  3. écrire les données dans le fichier Excel.
+0

Vous pouvez lire Excel comme datatable dans VBA trop –

1

Vous pouvez utiliser ADO.

Dim cn As Object 
Dim rs As Object 
Dim strFile As String 
Dim strCon As String 
Dim strSQL As String 
Dim s As String 
Dim i As Integer, j As Integer 

''This is not the best way to refer to the workbook 
''you want, but it is very convenient for notes 
''It is probably best to use the name of the workbook. 

strFile = ActiveWorkbook.FullName 

''Note that if HDR=No, F1,F2 etc are used for column names, 
''if HDR=Yes, the names in the first row of the range 
''can be used. 
''This is the Jet 4 connection string, you can get more 
''here : http://www.connectionstrings.com/excel 

strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & strFile _ 
    & ";Extended Properties=""Excel 8.0;HDR=Yes;IMEX=1"";" 

''Late binding, so no reference is needed 

Set cn = CreateObject("ADODB.Connection") 
Set rs = CreateObject("ADODB.Recordset") 


cn.Open strCon 

strSQL = "SELECT [Name] " _ 
     & "FROM [Sheet1$] a " _ 
     & "LEFT JOIN [Sheet2$] b " _ 
     & "ON a.[Name]=b.[Name] " _ 
     & "WHERE b.Name Is Null" 

rs.Open strSQL, cn, 3, 3 


''Pick a suitable empty worksheet for the results 

Worksheets("Sheet3").Cells(2, 1).CopyFromRecordset rs 

''Tidy up 
rs.Close 
Set rs=Nothing 
cn.Close 
Set cn=Nothing