質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.36%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Access

Accessはマイクロソフトによるリレーショナルデータベース管理システムです。オブジェクト指向のアプリケーション作成に対応しており、テーブルや編集をはじめ、クエリ生成、入力フォーム作成、レポート作成など一通りの機能を備えています。

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

Q&A

0回答

3109閲覧

VBAでACCESSのデータ取得時の配列への代入方法

退会済みユーザー

退会済みユーザー

総合スコア0

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Access

Accessはマイクロソフトによるリレーショナルデータベース管理システムです。オブジェクト指向のアプリケーション作成に対応しており、テーブルや編集をはじめ、クエリ生成、入力フォーム作成、レポート作成など一通りの機能を備えています。

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

0グッド

0クリップ

投稿2021/06/16 04:37

編集2021/06/16 05:57

VBA初心者です。
VBAでAccessからテーブルのデータを持ってきたいのですが、
日付の変換をするためにデータを一度、配列(ソースの太字)に入れたいのですが、
Splitだと型が違いエラーになってします。
解決できる方、よろしくお願いいたします。

※諸事情がありエラーが出ない状態でのすべてのコードを書くことができません。

質問の内容としては、
Accessからデータを取得しExcelに貼り付け、フォーマットの設定をする際に
日付の変換は特殊なので、その方法を知りたいです。
日付の変換をVBAで設定したい理由としては大量のデータ、大量のDBを扱うのでワンクリックですべてを簡潔させたいからです。

連想配列記載理由は、フィールドを取得する際に使用しています。

'連想配列用オブジェクト
Dim colDic As Object
Set colDic = CreateObject("Scripting.Dictionary")

'コネクション用変数宣言 Dim con As ADODB.Connection Dim rs As ADODB.Recordset '顧客管理のACCDBファイルに接続 Set con = New ADODB.Connection con.Provider = "Microsoft.Ace.OLEDB.12.0" con.Open "C:\work\Access.accdb" 'レコードセットを開く Set rs = New ADODB.Recordset 'Accessのクエリを開く rs.Open "AccessTable", con, adOpenStatic 'rs.fieldsの各要素を取得 Dim i As Integer i = 1 Dim k As Integer k = 0 'Feild名取得用変数 Dim fid As Object 'データの数分ループ For Each fid In rs.Fields 'フィールド名を各セルに代入 Range(Cells(firstCell.Row, i), Cells(firstCell.Row, i)) = fid.Name '表示形式用(連想配列へ格納) colDic.Add fid.Name, i 'iをインクリメント i = i + 1 Next fid With ws 'テーブルデータのレコード数の取得 Dim tableRow As Long tableRow = rs.RecordCount + firstCell.Row '最終列取得 Dim dataCol As Long dataCol = firstCell.Column + rs.Fields.Count - 1

** '配列に変換**
** Dim tmp() As String**
** tmp = Split(rs, ",")**

Dim d As Variant Dim n As Long For Each d In dateList n = colDic(d) tmp(n) = Format(tmp(n), "####/##/##") Next d

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hatena19

2021/06/16 05:24 編集

なんかコードが無茶苦茶です。コンパイルすら通りません。 ちゃんと実行できるコードを提示するか、 最終的にしたいことを言葉で説明できませんか。 Accessのテーブルデータをシート上に転記したいのなら、配列やら連想配列は必要ないです。 書式はエクセルのセルの書式設定ですればいいでしょう。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問