No.2ベストアンサー
- 回答日時:
エクセルのバージョンを書いて質問すること。
エクセル2003以前だと、「重複の削除」が無いのでは。エクセル2010?
ーー
こんな単品リクエストなら、一例の操作をして、「マクロの記録」を取ればコードが出てくるでしょう。
データ範囲は操作したときの選択したセル範囲(決定・固定)になっているから、
>一つの行に並べてあり
エクセルの通常使用法と違うと思う(普通は列方向にデータを増やすが)
行方向に増やしたものなら
Sub test02()
r = Range("IV2").End(xlToLeft).Column
MsgBox r
End Sub
でデータの存在する一番右の列がとらえられる。
ーー
これを使ってソート対象は
下記は2003以前用で IV2 となっているが一般的書き方ではMsgBox Columns.Countで示される数です。
Sub test02()
r = Range("IV2").End(xlToLeft).Column
MsgBox r
d = Range("A65536").End(xlUp).Row
MsgBox d
Range(Cells(2, "A"), Cells(d, r)).Select
End Sub
を参考にして。結果確認はシートタブのクリックで確認しないと選択範囲がくづれるの出注意。
Msgbox は納得できたら削除。
ーー
そのほかにも、データの在る範囲をとらえるVBAコードの方法は数種在る。
遅くなって申し訳ございません。
早速のご回答ありがとうございます。
分かりやすいご説明、誠にありがとうございます。
ご参考にさせていただきました。
また機会ありましたらよろしくお願いいたします。
No.1
- 回答日時:
マクロの記録で記録されたコードで勉強するのが基本かと。
記録されたコードを見てみると、記録した時のデータ件数(行数)の部分に柔軟性がないので、件数が何件あろうと柔軟に対応できるように書き換える必要が出る。
実際に質問者が想定しているデータ入力状態がわからないので、以下のように勝手に想像してみた。
・ セル A1 にタイトルがあり、A2 から下に向かって途切れなくデータが入っている。
・ セル A1 がアクティブになっている状態でマクロを実行する。
・ Excel 2007 または 2010 を使っている。(2003 以前ではコードが違う)
Dim startCell As Range ' 起点となるセル
Dim endCell As Range ' データの最終セル
Set startCell = ActiveCell ' アクティブになっているセルを起点とする。(セル A1 を想定)
Set endCell = startCell.End(xlDown) ' A1 から下に向かってデータが途切れるセルを最終セルとする
Dim currentSheet As Worksheet ' 対象シート
Set currentSheet = ActiveSheet ' 現在アクティブなシートを対象とする
' 現在のソート条件をクリアし、新たに設定する。
' A2 から最終セルまでを範囲とし、値を昇順で並び替える。
currentSheet.Sort.SortFields.Clear
currentSheet.Sort.SortFields.Add _
Key:=Range(startCell.Offset(1, 0), endCell), _
SortOn:=xlSortOnValues, _
Order:=xlAscending, _
DataOption:=xlSortNormal
' ソートを実行する。
' 起点セルから最終セルまでを対象とし、先頭行をタイトル行とし、大文字小文字を区別せず、行方向へ、振り仮名を使って並び替えを実行する。
With currentSheet.Sort
.SetRange Range(startCell, endCell)
.Header = xlYes
.MatchCase = False
.Orientation = xlTopToBottom
.SortMethod = xlPinYin
.Apply
End With
' 起点セルから最終セルまでの間で、ダブっているデータを削除する。
currentSheet.Range(startCell, endCell).RemoveDuplicates Columns:=1, Header:=xlYes
お礼
遅くなって申し訳ございません。
早速のご回答ありがとうございます。
分かりやすいご説明、誠にありがとうございます。
ご参考にさせていただきました。
また機会ありましたらよろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) 【マクロ】マクロが保存されているエクセルとは、別のエクセルブックの全シートの非表示列を再表示したい 1 2022/12/24 20:48
- Excel(エクセル) 【マクロ】マクロが保存されているエクセルとは、別のエクセルのオートフィルターのしぼりをクリアーしたい 2 2022/12/24 08:36
- Excel(エクセル) Excel 行 について 写真のように日付が並んでおり、何年何月何日以前は行削除。といったマクロ等組 2 2023/02/20 12:55
- Visual Basic(VBA) エクセルのマクロについて教えてください。 3 2023/07/07 08:37
- Visual Basic(VBA) vbaエクセルマクロ RemoveDuplicatesについて RemoveDuplicatesを使 1 2023/02/27 22:21
- Excel(エクセル) エクセルでのマクロを使ったデータの並べ替え 3 2022/12/03 18:54
- Visual Basic(VBA) vbaエクセルマクロ RemoveDuplicatesについて 重複したものがあれば行を削除するとい 1 2023/02/27 18:49
- Excel(エクセル) エクセルのマクロについて教えてください。 2 2023/01/25 11:42
- Excel(エクセル) VBA 指定した列にある日時データから時間を削除する方法について 4 2022/04/14 11:17
- Visual Basic(VBA) vbaエクセルマクロ RemoveDuplicatesについて RemoveDuplicatesを使 3 2023/02/28 01:13
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBAマクロ実行時エラーの修正に...
-
Excel UserForm の表示位置
-
特定の色のついたセルを削除
-
【VBA】【ユーザーフォーム_Lis...
-
エクセルVBA 配列からセルに「...
-
【Excel VBA】一番右端セルまで...
-
C# DataGridViewで複数選択した...
-
Excelで空白セル直前のセルデー...
-
Excel VBAでCheckboxの名前を変...
-
DataGridViewでグリッド内に線...
-
CellEnterイベント仕様について
-
関数の引数でrangeを指定したとき
-
ExcelVBAでセル選択範囲ウィン...
-
昨日、質問した件『VBA にて、...
-
Excel 範囲指定スクショについ...
-
VBA 検索結果の行を取得。上か...
-
入力規則のリスト選択
-
EXCEL 2010 VBAでピボットで複...
-
数式バーに表示される値(文字...
-
VBA にて、条件付き書式で背景...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBAマクロ実行時エラーの修正に...
-
Excel UserForm の表示位置
-
エクセルVBA 配列からセルに「...
-
EXCEL VBA 文中の書式ごと複写...
-
特定の色のついたセルを削除
-
【Excel VBA】一番右端セルまで...
-
Excelで空白セル直前のセルデー...
-
【VBA】写真の貼り付けコードが...
-
VBAコードについて教えてくださ...
-
【VBA】【ユーザーフォーム_Lis...
-
Excel 範囲指定スクショについ...
-
VBAでユーザーフォームにセル値...
-
VBA:日付を配列に入れ別セルに...
-
VBA にて、条件付き書式で背景...
-
Excel VBAでCheckboxの名前を変...
-
複数指定セルの可視セルのみを...
-
Excel VBA IF文がうまく動作し...
-
エクセルのカーソルを非表示に...
-
入力規則のリスト選択
-
VBA 複数条件の分岐処理の上手...
おすすめ情報