🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Q&A

解決済

2回答

1579閲覧

C#電卓 Convert部分のエラーを修正したいです

sin0508

総合スコア2

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

0グッド

0クリップ

投稿2020/12/31 04:34

編集2021/01/04 09:08

前提・実現したいこと

プログラミングをはじめて1か月程度のものです。
C#を使って電卓作成を行っています。
エラー箇所はConvertを使用したソース部分です。
Convertを使用する目的としては、
まず電卓のテキストボックスの初期値として入力されている「0」をButtonを押したときに消えるようにするためです。
例:「0」→「04」となってしまうのを「0」→(0を削除)「4」としたい

  次に計算のために一時的に入力された数字を数値として扱うためです。つまり文字列型と数値型の変換を行いたいです。
この部分にかれこれ数日苦戦しています。
参考書やネットをあさりまくっていますがうまくいきません。。

発生している問題・エラーメッセージ

decimalからstringの変換がうまくいっていないようです。
別ファイルにConvertを使った部分を書き込み、文字列型から数値型に正常に変換出来ているかを動作確認していますがそちらでは問題なく動作します。しかし、Convert部分が複数になるとエラーが発生してしまいます。イメージ説明

System.FormatException: '入力文字列の形式が正しくありません。'

このエラーメッセージがConvert部分のどれかに出てしまいます。

該当のソースコード

C#

1using System; 2using System.Collections.Generic; 3using System.ComponentModel; 4using System.Data; 5using System.Drawing; 6using System.Linq; 7using System.Text; 8using System.Threading.Tasks; 9using System.Windows.Forms; 10 11namespace 電卓_三号機 12{ 13 public partial class Form1 : Form 14 { 15 public Form1() 16 { 17 InitializeComponent(); 18 } 19 20 bool isFirst = true; 21 decimal 値1 = 0; 22 23 private void buttonNumber_Click(object sender, EventArgs e) 24 { 25 //四則演算が押されていた場合表示されている数字を記憶し消す 26 if (記号 != 四則演算の記号.未定義 && isFirst) 27 { 281 = Convert.ToDecimal(textDisplay.Text); 29 textDisplay.Text = ""; 30 isFirst = false; 31 } 32 textDisplay.Text = textDisplay.Text + ((Button)sender).Text; 33 34 //文字列 → 数値 35 decimal d = Convert.ToDecimal(textDisplay.Text); 36 37 //数値 → 文字列(先端の0が消える) 38 textDisplay.Text = d.ToString(); 39 40 } 41 42 private void buttonClaer_Click(object sender, EventArgs e) 43 { 44 textDisplay.Text = ""; 45 } 46 //小数点クリック 47 private void buttonDot_Click(object sender, EventArgs e) 48 { 49 //小数点の重複チェック 50 if (textDisplay.Text.IndexOf(".") >= 0) 51 { 52 //既に小数点がある 53 return; 54 } 55 textDisplay.Text = textDisplay.Text + "."; 56 } 57 58 enum 四則演算の記号 59 { 60 未定義,ADD, SUB, MUL, DIV 61 }; 62 63 四則演算の記号 記号; 64 65 private void buttonAdd_Click(object sender, EventArgs e) 66 { 67 記号 = 四則演算の記号.ADD; 68 isFirst = true; 69 } 70 71 private void buttonSub_Click(object sender, EventArgs e) 72 { 73 記号 = 四則演算の記号.SUB; 74 isFirst = true; 75 } 76 77 private void buttonMul_Click(object sender, EventArgs e) 78 { 79 記号 = 四則演算の記号.MUL; 80 isFirst = true; 81 } 82 83 private void buttonDiv_Click(object sender, EventArgs e) 84 { 85 記号 = 四則演算の記号.DIV; 86 isFirst = true; 87 } 88 89 private void buttonCalc_Click(object sender, EventArgs e) 90 { 91 //文字列 → 数値 92 decimal 値2= decimal.Parse(textDisplay.Text); 93 decimal 結果 = 0; 94 switch (記号) 95 { 96 case 四則演算の記号.ADD: 97 結果 =1 +2; 98 break; 99 case 四則演算の記号.SUB: 100 結果 =1 -2; 101 break; 102 case 四則演算の記号.MUL: 103 結果 =1 *2; 104 break; 105 case 四則演算の記号.DIV: 106 結果 =1 /2; 107 break; 108 } 109 textDisplay.Text = 結果.ToString(); 110 } 111 } 112} 113

試したこと

別ファイルにConvertを使った部分を書き込み、文字列型から数値型に正常に変換出来ているかを動作確認していますがそちらでは問題なく動作します。しかし、Convert部分が複数になるとエラーが発生してしまいます。
変換前の型が正しいかを確認しながら行いましたがどこが間違っているのかがわかりませんでした、、

補足情報(FW/ツールのバージョンなど)

visual studioの.Netframework(?)を使用しています。

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

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

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

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

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

YAmaGNZ

2020/12/31 04:46

エラーが出る時にConvert.ToDecimalに渡しているテキストの内容は確認しましたか?
sin0508

2021/01/04 09:09

返信が遅くなってしまい大変申し訳ありません。 sting を渡していると認識していましたが、間違っているのでしょうか、、 エラー時の画像を追加しました。
pepperleaf

2021/01/04 09:12

入力が全角になってませんか?
sin0508

2021/01/04 09:24

ボタンを押したときに入力される数字が ですか?
pepperleaf

2021/01/04 09:29

エラー時の画像にある textDisplay.text を見ると数字が全角に見えます。もしそうなら、当然エラー。
sin0508

2021/01/04 09:37

!!! 1だけが全角になっていました。。。 修正したところ無事動作しました。 ソースばかりに目がいって初歩の部分で間違えていました。。 本当にありがとうございます!
guest

回答2

0

visualstudioでデバック実行して、例外で停止したときConvert.ToDecimal()の引数をみれば原因がわかると思います。

イメージ説明

投稿2020/12/31 05:04

TaroToyotomi

総合スコア1448

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

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

sin0508

2021/01/04 09:12

返信が遅くなってしまい大変申し訳ありません。 Taroさんが載せてくださったエラー画面の引数と同じになっている気がします。。 それであっていると思っていましたがそもそもの認識が間違っていたかもしれません。。 自分のエラー画面の画像を追加しました。
sin0508

2021/01/04 09:43

すみません。 ボタンの1だけが全角になっており、そのボタンを押すことでエラーに繋がっていたようです。 初歩的すぎるミスでした。。 お手数おかけしました。
guest

0

ベストアンサー

VisualStudioを使ってるなら、任意の行でブレークポイントを設定すればそこで実行を中断できます
そして、1行づつ実行することもできます。
それで、どこでエラーが出るのかを特定しましょう

また、エラーが出る行で実行を止め、引数の文字列がなにかを見てみてください。
数字以外の文字が混じっていれば、提示のようなエラーとなります

投稿2020/12/31 04:48

y_waiwai

総合スコア88038

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

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

sin0508

2021/01/04 09:16

返信が遅くなってしまい大変申し訳ありません。 エラー画面の画像を追加しました。 引数を確認しましたがこれであっていると認識していました。。 渡す引数とその変換の認識がそもそも間違っていたかもしれません。
sin0508

2021/01/04 09:45

すみません。おっしゃる通りでした。 1だけが全角になっていました。。 初歩的すぎるミスをしてしまいました 修正したところ無事動作しました! お手数おかけしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問