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

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

ただいまの
回答率

90.33%

  • Python 3.x

    7440questions

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

Python 正規表現について

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 202

north_redwings

score 24

Pythonで入力した数が整数でも有理数でも計算できるプログラムを書きたいと思っています。

import re

class Rat:
    n = 0
    d = 0

    def __init__(self, n, d):
        self.n = n
        self.d = d

    def gcd(a, b):
        if(a % b == 0):
            return b
        else:
            return Rat.gcd(b, a % b)

    def __repr__(self):
        if(self.d / Rat.gcd(self.n, self.d) != 1):
            return '{}/{}'.format(int(self.n / Rat.gcd(self.n, self.d)), int(self.d / Rat.gcd(self.n, self.d)))
        elif(self.d / Rat.gcd(self.n, self.d) == 1):
            return '{}'.format(int(self.n / Rat.gcd(self.n, self.d)))

    def __add__(self, other):
        return Rat((self.n * other.d) + (self.d * other.n), (self.d * other.d))

    def __sub__(self, other):
        return Rat((self.n * other.d) - (self.d * other.n), (self.d * other.d))

    def __mul__(self, other):
        return Rat((self.n * other.n), (self.d * other.d))

    def __truediv__(self, other):
        return Rat((self.n * other.d), (self.d * other.n))


def is_int(arg):
    """
    int型かどうか調べる関数
    """
    try:
        int(arg)
        return True

    except ValueError:
        return False

def input_number():
    """
    標準入力で分数あるいは整数を受け取り、全て分数に変換して返す関数
    """
    while(True):
        msg = input("Number is fraction or integer? Enter (f or i):")

        if(msg == "i"):
            num = input("Enter integer:")
            if(is_int(num)):
                num = Rat(int(num), 1)
                break
            else:
                print("ValueError : not integer")
                continue

        elif(msg == "f"):
            tmp = input("Enter fraction like 3/5:")
            print(re.match("//", tmp))
            if(re.match("//", tmp)):
                tmp_list = re.split("//", tmp)
                print(tmp_list)
                if((is_int(tmp[0]) and is_int(tmp[1]))):
                    num = Rat(int(tmp[0]), int(tmp[1]))
                    print(num)
                    break
                else:
                    print("ValueError : not fraction")
                    continue

        elif(msg == "quit"):
            exit()

    return num

def main():
    num1 = input_number()
    num2 = input_number()

    print()
    print("Arithmetic of num1 & num2")
    print("({}) + ({}) = {}".format(num1, num2, num1 + num2))
    print("({}) - ({}) = {}".format(num1, num2, num1 - num2))
    print("({}) * ({}) = {}".format(num1, num2, num1 * num2))
    print("({}) / ({}) = {}".format(num1, num2, num1 / num2))
    print()

if __name__ == "__main__":
    main()

しかし、実行すると分数の"/"で分割して分数の分母分子を区別したいのに、コマンドラインで"/"を入力しても認識されません。おそらくは正規表現の部分でNoneと返って来ているのでその部分が怪しいと思うのですが・・・。

Yuji-no-MacBook-Air:tmp_file YujiNarita$ python hw0423.py
Number is fraction or integer? Enter (f or i):f
Enter fraction like 3/5:23/34
None
Number is fraction or integer? Enter (f or i):quit
Yuji-no-MacBook-Air:tmp_file YujiNarita$ python hw0423.py
Number is fraction or integer? Enter (f or i):i
Enter integer:6
Number is fraction or integer? Enter (f or i):i
Enter integer:8

Arithmetic of num1 & num2
(6) + (8) = 14
(6) - (8) = -2
(6) * (8) = 48
(6) / (8) = 3/4

Yuji-no-MacBook-Air:tmp_file YujiNarita$ 

なお、上記の通り、整数では問題なく計算できました。また、正規表現を使わず("/"をコマンドラインで入力し忘れるなどのErrorを無視して)書いた場合は有理数でも問題なく計算できたのでclass Ratの部分は間違っていないかと思われます。

もし記載不足などございましたらご指摘いただけると幸いです。また、コードの書き方などもご指摘いただければと思います。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

+2

tmp = input("Enter fraction like 3/5:")
print(re.match("//", tmp))

間違いが二つあります。

  1. re.matchは、先頭一致を判定するものです。
  2. スラッシュはメタ文字としての意味を持ちませんから、単に'/'でいいです。

単に『スラッシュが含まれるかどうか』を判定したいのであれば、正規表現は不要です。

tmp = input("Enter fraction like 3/5:")
print('/' in tmp)

なお

fractionsモジュールが標準で用意されているので、こちらを使うと楽です。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/05/10 16:06

    先頭だったんですね・・・。勉強不足でした。
    ()でキャプチャして成功しました、ありがとうございました。

    キャンセル

0

import re

class Rat:
    n = 0
    d = 0

    def __init__(self, n, d):
        self.n = n
        self.d = d

    def gcd(a, b):
        if(a % b == 0):
            return b
        else:
            return Rat.gcd(b, a % b)

    def __repr__(self):
        if(self.d / Rat.gcd(self.n, self.d) != 1):
            return '{}/{}'.format(int(self.n / Rat.gcd(self.n, self.d)), int(self.d / Rat.gcd(self.n, self.d)))
        elif(self.d / Rat.gcd(self.n, self.d) == 1):
            return '{}'.format(int(self.n / Rat.gcd(self.n, self.d)))

    def __add__(self, other):
        return Rat((self.n * other.d) + (self.d * other.n), (self.d * other.d))

    def __sub__(self, other):
        return Rat((self.n * other.d) - (self.d * other.n), (self.d * other.d))

    def __mul__(self, other):
        return Rat((self.n * other.n), (self.d * other.d))

    def __truediv__(self, other):
        return Rat((self.n * other.d), (self.d * other.n))


def is_int(arg):
    """
    int型かどうか調べる関数
    """
    try:
        int(arg)
        return True

    except ValueError:
        return False

def input_number():
    """
    標準入力で分数あるいは整数を受け取り、全て分数に変換して返す関数
    """
    while(True):
        msg = input("Number is fraction or integer? Enter (f or i):")

        if(msg == "i"):
            num = input("Enter integer:")
            if(is_int(num)):
                num = Rat(int(num), 1)
                break
            else:
                print("ValueError : not integer")
                continue

        elif(msg == "f"):
            tmp = input("Enter fraction like 3/5:")
            m = re.match("(\d+)(/)(\d+)", tmp)
            if m:
                num = Rat(int(m.group(1)), int(m.group(3)))
                break
            else:
                print("ValueError : not fraction")
                continue

        elif(msg == "quit"):
            exit()

    return num

def main():
    num1 = input_number()
    num2 = input_number()

    print()
    print("Arithmetic of num1 & num2")
    print("({}) + ({}) = {}".format(num1, num2, num1 + num2))
    print("({}) - ({}) = {}".format(num1, num2, num1 - num2))
    print("({}) * ({}) = {}".format(num1, num2, num1 * num2))
    print("({}) / ({}) = {}".format(num1, num2, num1 / num2))
    print()

if __name__ == "__main__":
    main()

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.33%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • Python 3.x

    7440questions

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