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

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

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

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

Q&A

解決済

2回答

4922閲覧

Excel  VBA 値での貼り付け 改行

minakosun

総合スコア4

VBA

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

0グッド

0クリップ

投稿2021/10/29 04:15

Excelで特定シートの行をコピーして別シートに張り付けるVBAのマクロを組んでいたのですが値での貼り付けと改行ができません。
何か解決方法はありますでしょうか?

よろしくお願いいたします。

Sub Merge()

Dim MergeBook As Workbook Dim CurrentBook As Workbook Dim CurrentPath As String Dim Filename As String Dim n As Integer Application.ScreenUpdating = False Set MergeBook = ThisWorkbook Dim MergeSheet As Worksheet Set MergeSheet = MergeBook.Worksheets.Add MergeSheet.Name = "集計" CurrentPath = MergeBook.Path Filename = Dir(CurrentPath & "*.xls?") n = 0 Do While Filename <> Empty If Filename <> MergeBook.Name Then Set CurrentBook = Workbooks.Open(CurrentPath & "\" & Filename) Dim ws As Worksheet For Each ws In CurrentBook.Worksheets ws.Range("AJ1:AK500").Copy ws.Range("AJ1:AK500").PasteSpecial Paste:=xlPasteValues MergeSheet.Range("A" & MergeSheet.Rows.Count).End(xlUp).Offset (1) Next CurrentBook.Close False n = n + 1 End If Filename = Dir Loop Application.ScreenUpdating = True MsgBox n & "件のブックを処理しました。"

End Sub

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

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

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

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

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

guest

回答2

0

セル内改行は、セルの書式が「折り返して全体を表示」になっていないと改行して見えなかったと。
ですので、

VBA

1ws.Range("AJ1:AK500").PasteSpecial Paste:=xlPasteValues

このあとに、以下を追記すればよろしいかと。

VBA

1ws.Range("AJ1:AK500").WrapText = True

投稿2021/10/29 05:12

hex309

総合スコア761

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

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

0

ベストアンサー

>ws.Range("AJ1:AK500").Copy
>ws.Range("AJ1:AK500").PasteSpecial Paste:=xlPasteValues

これですと同じ場所にコピペしてますよね?
それに貼り付ける際にはセル範囲の左上のセルを指定するだけで宜しいかと。この場合なら"AJ1"でしょうか。

目的が不明ですが仮にMergeSheetのA列を基準として貼り付けるのなら貼り付け先は、

MergeSheet.Range("A" & MergeSheet.Rows.Count).End(xlUp).Offset(1).PasteSpecial Paste:=xlPasteValues

例えばこんな感じでしょうか。

投稿2021/10/29 05:10

megu_min19375

総合スコア26

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

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

minakosun

2021/10/29 06:40

ありがとうございます!わかりやすくて理解もできました! 値での貼り付けに成功しました! 改行については nの数式がうまく使えていなくて作用していないみたいなんです。 一回ペーストした後に右の空白セルの先頭に改行してからペーストを繰り返しているつもりなのですが。。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問