
No.5
- 回答日時:
こんにちは。
KenKen_SP です。試しにコードを書いていたら、Wendy02 さんに先を越されました(^^)
似たようなコードですが、折角書いたので(←自分勝手)アップさせて下さい。
Sub URL抽出()
Dim RegEx As Object
Dim strPattern As String
Dim objMatches As Object
Dim objItem As Object
Dim rngCell As Range
Dim Source As String
Dim lngCounter As Long
Dim Buf() As String
'URLパターン
strPattern = "((http|https|ftp)://[-_.!~*'()a-zA-Z0-9;/?:@&=+$,]+)"
'マッチング
lngCounter = 0
Set RegEx = CreateObject("VBScript.RegExp")
With RegEx
.Pattern = strPattern
.Global = True
For Each rngCell In Selection
If Not IsEmpty(rngCell) Then
Source = StrConv(Trim$(rngCell.Text), vbNarrow Or vbLowerCase)
Set objMatches = .Execute(Source)
For Each objItem In objMatches
ReDim Preserve Buf(lngCounter)
Buf(lngCounter) = objItem
lngCounter = lngCounter + 1
Next objItem
Set objMatches = Nothing
End If
Next rngCell
End With
Set RegEx = Nothing
'結果出力
With ActiveWorkbook.Sheets.Add
.Range("A1").Resize(UBound(Buf) + 1).Value = _
Application.Transpose(Buf)
End With
End Sub
No.4
- 回答日時:
こんにちは。
>むちゃくちゃな羅列のテキストがあるのですが、その中にいくつかhttp://~で始まる文があります。
マクロを希望されているので、設定等は細かく書きません。範囲をマクロで選択してからお使いください。むちゃくちゃな羅列のテキストというのは、どういうものか分かりませんから、URL の末尾の文字の判定をどうするか、少し、不安な部分があります。
現在、別シートというのを、「Sheet2」に設定してありますので、任意で変更してください。
'<標準モジュール>
Sub PickupURL()
Dim objRE As Object
Dim Match As Object, Matches As Object
Dim Rng As Range
Dim c As Range, i As Long, u As Long
Dim myArray() As Variant
Set Rng = Selection
Set objRE = CreateObject("VBScript.RegExp")
With objRE
.Pattern = "(http://\S+)"
.Global = True
For Each c In Rng
Set Matches = .Execute(c.Text)
For Each Match In Matches
ReDim Preserve myArray(i)
myArray(i) = .Replace(Match, "$1")
i = i + 1
Next
Next
End With
If i = 0 Then Exit Sub
u = UBound(myArray) - LBound(myArray) + 1
'別シートのA1から下に出力
Worksheets("Sheet2").Range("A1").Resize(u) = myArray
Set objRE = Nothing
End Sub
この回答への補足
ご回答ありがとうございました。
さっそく試してみましたが、最初に見つけたURLは抽出してくれたのですが、
その同じURLが複数リスト化されました。
どうも思っていた動きと違うみたいです。
修正しようにも自分には技量不足みたいです。。。
プログラムが組めてうらやましいです。
とても参考になりました。
本当にありがとうございました。
No.3
- 回答日時:
質問文でよくわからない点もあるんですが、探してきました。
検索したい文字列を入力すると、Sheet1のA列を検索して
該当するデータをSheet2に抽出するマクロ
http://park11.wakwak.com/~miko/Excel_Note/16-01_ …
ただこれでURL部分のみを抜き出したい場合、URLのみで構成される単独行でないとできません。
なんか質問文を見ると“あるテキストからURLのみを抜き出したい。”というのが目的で
EXCELでやるという必要性がうかがえないのですが。
もしEXCELでなくてもよいなら秀丸マクロを使う方法もあります。
http://hide.maruo.co.jp/lib/macro/listup101.html
こちらはやり方にも寄りますが、URL部分のみを抜き出せます。
No.1
- 回答日時:
こんにちは~
そのテキストは特定の列にあるんでしょうか?
そうだとして、作業列を使ってもよいなら以下の方法で。
テキストがSheet1のA列1行目からあり、作業列をB列とすれば、
B1に、
=IF(LEFT(A1,7)="http://",ROW(),"")
を入れ、下にフィルコピー
別シートのどのセルでもいいので、
=IF(COUNT(Sheet1!B:B)<ROW(A1),"",INDEX(Sheet1!A:A,SMALL(Sheet1!B:B,ROW(A1))))
を入れ、必要分、下にフィルコピー
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) Excel>マクロ>特定のセルで同じ情報が登録されている行を1行にまとめたい(文字連結) 6 2023/01/05 16:30
- Excel(エクセル) エクセルで2つの表を比較して、文字列が同じだが、その行のある値が違うものを抽出したい 1 2022/10/06 21:48
- Excel(エクセル) Excel 文字列を結合するときに重複をなくしたい 関数・VBA 2 2022/12/12 10:40
- Excel(エクセル) Excelの担当者割当の表から担当者を抽出する方法 4 2022/07/16 14:05
- Excel(エクセル) Excelの関数でこんな処理ができますか 1 2023/02/08 13:46
- Visual Basic(VBA) SQLで抽出 4 2022/12/04 13:55
- Excel(エクセル) 関数EXACT(文字列,文字列)とexcelVBA 3 2022/04/14 15:07
- その他(データベース) Accessのクエリで1フィールドの抽出条件設定をNullでなく全角半角含む空白のみの文字列でない文 1 2023/04/24 15:20
- Visual Basic(VBA) 特定の文字を簡単な操作で半角スペースに変換するか削除したい 2 2022/11/01 10:35
- Excel(エクセル) マクロ削除再抽出する方法を教えて下さい。 6 2022/11/26 11:03
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルVBA 列検索後に該当デ...
-
Excel複数シートにあるデータを...
-
エクセルで、チェックボックス...
-
Excel 2段組み
-
シートをまたぐ条件付き書式に...
-
【条件付き書式】countifsで複...
-
マクロか関数で処理したいので...
-
ある数値に対して、値を返す数...
-
エクセルVBA データを別シート...
-
エクセルVBAで、ある文字を含ん...
-
Excelにて、ファイル内の複数シ...
-
VLOOKUP関数の引数は文字列はダ...
-
VLOOKアップ関数の結果の...
-
エクセルのマクロで重複データ...
-
【Excel】ある文字列からはじま...
-
エクセルのブック分割マクロを...
-
Excelでの並べ替えを全シートま...
-
エクセルマクロでデータ出力の...
-
Excel の複数シートの列幅を同...
-
EXCEL 関数を教えてください。...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
文字の色も参照 VLOOKUP
-
ExcelのVlookup関数の制限について
-
【条件付き書式】countifsで複...
-
エクセルの保護で、列の表示や...
-
Excelのセルの色を変えた行(す...
-
エクセルで、チェックボックス...
-
VBAで繰り返しコピーしながら下...
-
シートをまたぐ条件付き書式に...
-
Excelでの並べ替えを全シートま...
-
Excel の複数シートの列幅を同...
-
Excelに自動で行の増減をしたい...
-
【VBA】複数のシートの指定した...
-
【エクセル】1列のデータを交...
-
SUMPRODUCTにて別シートのデー...
-
Excel 2段組み
-
エクセル マクロ 標準モジュー...
-
エクセルの列の限界は255列以上...
-
excel 複数のシートの同じ場所...
-
エクセルVBAで、ある文字を含ん...
-
VLOOKアップ関数の結果の...
おすすめ情報