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

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

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

Python 2.7は2.xシリーズでは最後のメジャーバージョンです。Python3.1にある機能の多くが含まれています。

正規表現

正規表現とは特定の文字列によるパターンマッチングを行う際に用いられる宣言型プログラミングです。

Q&A

2回答

3524閲覧

文章中から一文を抜き出す正規表現

mae

総合スコア45

Python 2.7

Python 2.7は2.xシリーズでは最後のメジャーバージョンです。Python3.1にある機能の多くが含まれています。

正規表現

正規表現とは特定の文字列によるパターンマッチングを行う際に用いられる宣言型プログラミングです。

0グッド

0クリップ

投稿2015/09/07 01:50

pythonで、以下の例文から?で終わる一文を抽出する正規表現を教えてください。
[^。]+?
上記の正規表現を書いたところ、pythonでは動作しませんでした。よろしくお願いいたします。

【例文】
このモジュールでは、 Perl で見られるものと同様な正規表現マッチング操作を提供しています。パターンと検索対象文字列の両方について、 8 ビット文字列と Unicode 文字列を同じように扱えます。正規表現では、特殊な形式を表したり、特殊文字の持つ特別な意味を呼び出さずにそ の特殊な文字を使えるようにするために、バックスラッシュ文字を使います。こうしたバックスラッシュの使い方は、 Python の文字列リテラルに おける同じバックスラッシュ文字と衝突を起こします? と表現せねばならないからです。

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

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

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

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

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

guest

回答2

0

正規表現としては正しいと思いますのでPhytonでの検索手順に問題があるのではないでしょうか?
自分はPhytonは未経験なのですが、Phytonで書いたソースコードを提示していただけるとわかる方が回答してくれるかもしれません。

ちなみに「Phyton 正規表現 全角」でググるとUnicodeで検索するような文献が見受けられました。

以下、それらを参考に記述してみました。

import re words = u"あああ。いいい。ううう?えええ。" reg = u"([^。]+\?)" match = re.search(reg, words, re.U): if match is None: print 'Not match' else: print match.group(1)

Phyton未経験者の机上コードなので動作するかも参考になるかもわかりませんが、悪しからず^^;

投稿2015/09/07 09:15

jawa

総合スコア3013

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

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

0

単にエスケープの表記ミスではないでしょうか。
[^。]+?
pythonにて?というエスケープ文字が検出されますが、存在しません。

[^。]+\?
こうすることで、

テキスト表現:[^。]+\\? ↓ Python文字列:[^。]+\? ↓ 正規表現文字列:[^。]+?

とエスケープされるはずです。

投稿2016/07/19 07:23

intelf___

総合スコア868

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問