Можно ли создать внешнее соединение VBA QueryTable между файлом CSV и рабочим листом? - PullRequest
1 голос
/ 11 февраля 2011

Я создаю книгу Excel для управления моими личными финансами. Мои банки предоставляют данные транзакций в формате CSV, и я нашел способ импортировать эти данные в Excel, используя QueryTable (используя соединение «TEXT»).

Я хочу автоматически применять правила категории транзакций к каждой импортируемой транзакции. У меня есть лист с двумя столбцами - строка для сопоставления с «подробностями» транзакции, указанными в CSV-файле моего банка, и категория для применения к соответствующим транзакциям.

Можно ли создать внешнее соединение между данными CSV и рабочим листом категорий и вывести полученную таблицу в другой рабочий лист?

Например (псевдокоде SQL): SELECT csv.date, csv.details, csv.debit, csv.credit, ws.category FROM [csvfile] csv СЛЕДУЮЩЕЕ ВСТУПЛЕНИЕ [рабочий лист] ws ON csv.details ~ = ws. детали

~ = выше будет какое-то совпадение строк. Я могу понять SQL, мой вопрос на самом деле, как объединить файл CSV и лист в одном QueryTable.

Ответы [ 3 ]

2 голосов
/ 11 февраля 2011

Excel будет открывать CSV-файлы, не мигая, но вы можете использовать строку подключения, если хотите. Можно даже написать запрос, который сравнивает существующий рабочий лист или именованный диапазон с текстовым файлом, используя соединение Excel. Все, что вам нужно, это немного VBA.

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

'Note HDR=Yes, that is, first row contains field names '
'and FMT delimted, ie CSV '
strCon="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=c:\Docs\;" _
& "Extended Properties=""text;HDR=Yes;FMT=Delimited"";"

cn.open strcon

'You would not need delimiters ('') if last field is numeric: '    
strSQL="SELECT FieldName1, FieldName2 FROM The.csv " _
& " WHERE LastFieldName='SomeTextValue'"

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

Вы можете использовать любые подходящие запросы Jet SQL к соединению, просто будьте осторожны с учетом регистра. Например, работа с подключением к текущей книге:

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 * " _
       & "FROM [Sheet1$] a " _
       & "LEFT JOIN [Text;FMT=Delimited;HDR=Yes;" _
       & "DATABASE=C:\Docs].Import.txt b " _
       & "ON a.[Id]=b.[Id] "

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
1 голос
/ 08 июня 2011

Можно создать OUTER JOIN, ссылающийся на разрозненные источники данных (CSV, Excel, Access, TXT, SQL, Oracle и т. Д.), Используя имена ISAM в запросе ADO.Результаты хранятся в наборе записей, который может быть опубликован обратно в Excel или другой источник данных по желанию.Google "SQL ISAM Names", чтобы найти мои другие сообщения на эту тему.

0 голосов
/ 11 февраля 2011

Я уверен, что немного больше информации поможет мне устранить путаницу, но я не верю, что можно настроить SQL-запрос к CSV, так как Excel не распознает его как источник данных.

Задумывались ли вы о простой загрузке CSV в Excel и создании сводной таблицы / поисков по данным?

...