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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

解決済

1回答

642閲覧

[Python3 `.find()` 文字列検索] 「または」の設定方法

Yukiya025

総合スコア86

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

1グッド

0クリップ

投稿2018/10/20 04:22

編集2018/10/20 05:30

こんにちは! 取得した文字列で3つの文字列のうちどれがあるか、またはないのかを検索したいです。しかし、「または」の設定方法がわかりません。

現在のコード

python

1 r = requests.get("https://www.oreilly.co.jp/index.shtml") 2 r.encoding = r.apparent_encoding 3 html_doc = r.text 4 soup = BeautifulSoup(html_doc) 5 6 html1 = open('Oreilly.html', 'w') 7 html1.write(soup.prettify()) 8 text1 = open('Oreilly.text', 'w') 9 text1.write(soup.get_text()) 10 text1 = soup.get_text() 11 12 index = text1.find("privacy policy" or "プライバシーポリシー" or "個人情報") # 13 if index != -1: 14 print("Found at " + str(index)) 15 else: print("Not found")

index = text1.find("個人情報")のみにすると出力結果がFound at 3787 となるのですが、orを足すとNot foundが出力されます。
「または」はどのように設定すれば良いでしょうかorz
よろしくお願いしますm(__)m

text1の中身の一部

text

1新刊情報 2カタログ 3Makezine 4オラの村 5 6 7取扱書店 8Bookclub 9フィードバック 10ご注文 11企業概要 12個人情報について

できました<3

hayataka2049様のおかげで判定できるようになりました! ありがとうございます(≧▽≦) 以下の点も気をつけます^^/

re.search()はマッチしなかったときNoneを返すので、結果を受け取る部分のコードに多少気を使ってあげてください

python

1def get_html(): 2 3 r = requests.get("https://www.oreilly.co.jp/index.shtml") 4 r.encoding = r.apparent_encoding 5 html_doc = r.text 6 soup = BeautifulSoup(html_doc) 7 8 html1 = open('Oreilly.html', 'w') 9 html1.write(soup.prettify()) 10 html1 = soup.prettify() 11 12 text1 = open('Oreilly.text', 'w') 13 text1.write(soup.get_text()) 14 15 priv_htm = re.search(r"privacy policy|プライバシーポリシー|個人情報", html1).start() 16 if priv_htm != -1: 17 print(priv_htm) 18 print("hrefを取得します") 19 20 else: print("ありませんでした") 21get_html()
achala👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

findメソッドでは複数の呼び出しを組み合わせない限り無理だと思います。、正規表現モジュールreを使って書いた方がスマートでしょう。

python

1import re 2 3txt = """ 4新刊情報 5カタログ 6Makezine 7オラの村 8 9 10取扱書店 11Bookclub 12フィードバック 13ご注文 14企業概要 15個人情報について 16""" 17 18print(txt.find("個人情報")) # => 58 19print(re.search(r"privacy policy|プライバシーポリシー|個人情報", txt).start()) # => 58

投稿2018/10/20 04:48

hayataka2049

総合スコア30933

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

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

Yukiya025

2018/10/20 05:04

hayataka2049様、ありがとうございます! おかげさまでできました<3
hayataka2049

2018/10/20 05:07 編集

re.search()はマッチしなかったときNoneを返すので、結果を受け取る部分のコードに多少気を使ってあげてください
Yukiya025

2018/10/20 05:08

了解です(≧▽≦)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問