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

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

新規登録して質問してみよう
ただいま回答率
85.35%
スクレイピング

スクレイピングとは、公開されているWebサイトからページ内の情報を抽出する技術です。

VBA

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

Chrome

Google Chromeは携帯、テレビ、デスクトップなどの様々なプラットフォームで利用できるウェブブラウザです。Googleが開発したもので、Blink (レンダリングエンジン) とアプリケーションフレームワークを使用しています。

selenium

Selenium(セレニウム)は、ブラウザをプログラムで作動させるフレームワークです。この原理を使うことにより、ブラウザのユーザーテストなどを自動化にすることができます。

Q&A

解決済

1回答

1686閲覧

vbaで文字列から数字のみを抽出する方法を知りたい

m-nm0n

総合スコア15

スクレイピング

スクレイピングとは、公開されているWebサイトからページ内の情報を抽出する技術です。

VBA

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

Chrome

Google Chromeは携帯、テレビ、デスクトップなどの様々なプラットフォームで利用できるウェブブラウザです。Googleが開発したもので、Blink (レンダリングエンジン) とアプリケーションフレームワークを使用しています。

selenium

Selenium(セレニウム)は、ブラウザをプログラムで作動させるフレームワークです。この原理を使うことにより、ブラウザのユーザーテストなどを自動化にすることができます。

0グッド

0クリップ

投稿2021/09/02 13:36

VBAについて、

以下のコードで取得したヤフオクの価格「○○円」から「円」を取り除き、数字のみ抽出するコードを追加していただけないでしょうか?

VBA

1driver.Get "https://page.auctions.yahoo.co.jp/jp/auction/n1002661605" 2 3Dim now_price As String 4now_price = driver.FindElementByCss("#l-sub > div.ProductInformation > ul > li.ProductInformation__item.js-stickyNavigation-start > div > div.Price__borderBox > dl > dd.Price__value").Text

以下のページを見てみたのですが、自分のコードへの応用がわかりませんでした。

https://nkmrdai.com/%E3%80%90%E8%A7%A3%E8%AA%AC%E4%BB%98%E3%80%91excel-vba%E3%81%A7%E6%96%87%E5%AD%97%E5%88%97%E3%81%8B%E3%82%89%E6%95%B0%E5%AD%97%E3%81%AE%E3%81%BF%E3%82%92%E6%8A%BD%E5%87%BA%E3%81%99%E3%82%8B%E6%96%B9/

ChromeをVBAのSeleniumでスクレイピングしています。

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

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

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

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

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

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

guest

回答1

0

ベストアンサー

標準モジュールに渡された文字列から数字のみを抽出する関数を作成しておけばいい

以下を標準モジュールに定義

Public Function FuncRetNum(ByVal strInput As String) As String
Dim lngLoop As Long
Dim strReturn As String

strInputWork = StrConv(strInput, vbNarrow)

For lngLoop = 1 To Len(strInputWork)
If IsNumeric(Mid(strInputWork, lngLoop, 1)) Then
strReturn = strReturn & Mid(strInputWork, lngLoop, 1)
End If
Next lngLoop

FuncRetNum = strReturn
End Function

あとは以下のように呼び出す

dim strText as String
strText = FuncRetNum("対象の果物は1,000円")

strTextに入る文字列の値は 1000

投稿2021/09/02 16:09

taopaipai

総合スコア17

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

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

m-nm0n

2021/09/02 22:07

ありがとうございます! 解決しました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問