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

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

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

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

Q&A

解決済

1回答

5290閲覧

VBA リストボックス 行移動

退会済みユーザー

退会済みユーザー

総合スコア0

VBA

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

0グッド

0クリップ

投稿2018/06/28 06:59

編集2018/07/02 00:10

リストボックス内のファイルをボタンで行ごと上下に一行移動できるようにしたいのですが、下記の処理をした際にリストボックスの2列目が消えてしまいます。
よろしくお願い致します

VBA

1Private Sub btn_FileOpen_Click() 2 Dim OpenFileName As Variant, Target As Variant 3 'カレントディレクトリを指定 4 ChDrive "C" 5 ChDir "C:\test" 6 OpenFileName = Application.GetOpenFilename(FileFilter:="Microsoft Excelブック,*.xls?", _ 7 MultiSelect:=True) 8 If IsArray(OpenFileName) Then 9 With Me.BookInput 10'リストボックスにファイル名を表示 11 For Each Target In OpenFileName 12 .AddItem Mid(Target,InstrRev(Target,"\")+1) 13 Pathname = Replace(Target, Filename, "") 14 .AddItem "" 15 .List(BookInput.ListCount - 1, 0) = Filename 16 .List(BookInput.ListCount - 1, 1) = Pathname 17 Next Target 18 End with 19 Else 20 MsgBox "キャンセルされました" 21 End If 22End Sub 23Private Sub btn_Fileup_Click() 24 Dim n As Long, buf As String 25 n = BookInput.ListIndex ''(1)現在選択されている位置を記憶する 26 buf = BookInput.List(n) ''(2)現在選択されているデータを記憶する 27 BookInput.RemoveItem n ''(3)現在選択されている位置のデータを削除する 28 BookInput.AddItem buf, n - 1 ''(4)1つ上の位置にデータを追加する 29End Sub 30Private Sub btn_Filedown_Click() 31End Sub

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

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

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

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

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

guest

回答1

0

ベストアンサー

buf = BookInput.List(n)では先頭列しか取得できないので、列ごとに取得する必要がありそうです。

VBA

1Dim n As Long, buf1 As String, buf2 As String 2n = BookInput.ListIndex ''(1)現在選択されている位置を記憶する 3buf1 = BookInput.List(n, 0) ''(2)現在選択されているデータを記憶する 4buf2 = BookInput.List(n, 1) ''(2)現在選択されているデータを記憶する 5BookInput.RemoveItem n ''(3)現在選択されている位置のデータを削除する 6BookInput.AddItem "", n - 1 ''(4)1つ上の位置に行を追加する 7BookInput.List(n - 1, 0) = buf1 ''(4)1つ上の位置にデータを追加する 8BookInput.List(n - 1, 1) = buf2 ''(4)1つ上の位置にデータを追加する 9

投稿2018/06/28 07:49

ttyp03

総合スコア17000

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

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

退会済みユーザー

退会済みユーザー

2018/06/28 08:48

ttyp03さん〉 列ごとに取得すれば良かったのですね。 解決しました。 回答ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問