Bonjour à tous,

Je rencontre un problème lorsque je veux effectuer ma requête SQL sur un fichier csv (je passe par une connexion ADODB).

Voici mon code :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
 
Sub Methode4()
 
    Dim Cn As ADODB.Connection
    Dim Fichier As String
    Dim NomFeuille As String, texte_SQL As String
    Dim Rst As ADODB.Recordset
    Dim n As Long
    Dim dat As String
 
    n = 2
    Dossier = "C:\TEMP\PROD_COMPAR\"
    FichierCSV = Dir(Dossier)
 
Do While FichierCSV <> ""
 
    'Connexion classeur fermé
    Set Cn = New ADODB.Connection
    Cn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Dossier & ";Extended Properties=""text;HDR=Yes;FMT=Delimited(;)"";Persist Security Info=False"
    Cn.Open
 
    'Requête Nb Valeurs
    texte_SQL = "SELECT COUNT(*) FROM " & FichierCSV
    Set Rst = New ADODB.Recordset
    Set Rst = Cn.Execute(texte_SQL)
    Workbooks("Ecarts MDC_SDC - Copie").Sheets(1).Range("B" & n).CopyFromRecordset Rst
 
    'Requête Ecarts TypeG
    texte_SQL = "SELECT COUNT(*) FROM " & FichierCSV & " WHERE CH0FO2-AV = 'FC'"
    Set Rst = Cn.Execute(texte_SQL)
    Workbooks("Ecarts MDC_SDC - Copie").Sheets(1).Range("C" & n).CopyFromRecordset Rst
 
    'Passer au fichier suivant
    n = n + 1
    FichierCSV = Dir()
 
    'Déconnexion classeur fermé
    Rst.Close
    Set Rst = Nothing
    Cn.Close
    Set Cn = Nothing
 
Loop
 
End Sub
La première requête fonctionne mais la deuxième où je rajoute une condition dans le WHERE j'obtiens l'erreur suivante :
Erreur d'exécution '-2147217904 (80040e10)':
Aucune valeur donnée pour un ou plusieurs des paramètres requis.

Apparement cette erreur est censée apparaitre lorsque le nom de colonne n'existe pas.
Mais le champ CH0FO2-AV existe bien dans la première ligne de mon fichier CSV.

Merci d'avance si vous pourrez m'aider.

Mathilde