ある変数に 文字列として 数値が格納されている。
ノイズがあり、時には その変数に 英字数字のごちゃ混ぜ文字列が入るときがある。
文字列には数字だけが入っている前提で処理すると、時に
その場合、Argument "○○"isn't numeric in addition・・・エラーがでてしまう。
このエラーを出力したくない、エラーログファイルに 読込エラーだったレコード内容を吐き出すようにしたい。
文字列が数字のみで構成されている場合は ○○を実行し、数字以外で構成されている場合は XXを実行するという if文を作成したいと考えている。よい判定方法を教えてください。
現在は、
$i=$i+0;
if( $i =~ /^\d+$/ ){ ○○} else{ XX}としているが、
$i=$i+0; の行でエラーが出てしまうときがある。
A 回答 (6件)
- 最新から表示
- 回答順に表示
No.6
- 回答日時:
「(先頭に空白があるかもしれない) 数字」なら
/^\s*\d+$/
でチェックできる.
ただ, #4 とそれへの「お礼」を読み返すと, なんかおかしい. 「数字以外だったら、$i=$i+0;をしないようにするように考えております。」のあとに「その数字チェックのやり方を知りたいと思っております。」がくるって, おかしいと思わない? どのように「数字チェックをした」としても, それと「数字以外だったら、$i=$i+0;をしないようにする」は直接つながらないでしょ? そして, 少なくともこの質問文からは「数字以外だったら、$i=$i+0;をしないようにする」という意図が見られない.
No.5
- 回答日時:
あなたのいう「数字」とやらがどのような形式のものであるかがわかれば「チェックの方法」を書けるかもしれません.
秒数が入っているので、本来は 0 もしくは 正の整数が入っている項目です。
ただし、空だったり、abcなどの数字以外が入ってくる場合があり、エラーメッセージなく 処理したいと思っております。
エラーがはきだされるレベルであれば、現状処理はできているのですが、エラーメッセージをなくし、エラーの場合はその行自体を 別のログファイルに吐き出ししたいと考えております。
この情報で、解決できますでしょうか?
No.4
- 回答日時:
根本的な間違いがあるようですね。
どんな方法を使おうが、判定をした結果を生かしてないようです。
判定して数値以外が含まれていたら演算をしてはダメですよ。演算した途端にエラーになります。
計算できないのであたりまえですよね?
判定して数値以外があったら、
$i=$i+0;
は実行しないようにしていますよね?
ご指摘の通り、数字以外だったら、$i=$i+0;をしないようにするように考えております。
その数字チェックのやり方を知りたいと思っております。
数字チェックの際に、Argument ~ メッセージがでてしまわない方法が知りたいのです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(コンピューター・テクノロジー) 【Tableau Desktop】文字列から8桁の数字を日付型(yyyyMMdd)として取得 1 2023/07/31 10:17
- Excel(エクセル) エクセル 関数について質問です。 2 2022/10/03 11:14
- Visual Basic(VBA) VBA 改行コードの取り方 1 2022/03/22 14:14
- Java Java 南京錠 2 2023/02/04 11:46
- Visual Basic(VBA) VBAで、特定の文字より後を削除して残った数値を文字列に変換と特定の文字より前も削除したい 3 2022/04/15 19:21
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- Excel(エクセル) Excelの関数についておしえてください。 3 2023/04/20 18:36
- PHP c言語 文字 - '1'+26 3 2022/03/26 20:58
- C言語・C++・C# int temp = 0; if(isdigit(arr[i])){//文字が数字であれば(0~9) 1 2022/03/27 01:37
- Excel(エクセル) エクセルのマクロについて教えてください。 1 2023/02/25 16:07
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセル関数を教えてください
-
UserForm1.Showでエラーになり...
-
エクセルVBA 「On Error GoTo...
-
ACCESS VBAのSplit()関数の使用...
-
マクロの「SaveAs」でエラーが...
-
Excel vbaについての質問
-
ステートメントが見つかりません
-
実行時エラー 438 の解決策をお...
-
VBScriptのエラー処理について
-
「実行時エラー '3167' レコー...
-
JAVA Jasper Report でのQRコー...
-
VBでSQL文のUPDATE構文を使った...
-
マクロで"#N/A"のエラー行を削...
-
お助けください!VBAのファイル...
-
Unityのエラー「Rigidbody.AddF...
-
エクセルVBAで埋め込みグラフ(C...
-
VBスクリプトでIEの404 not fou...
-
ある1人の友達のLINEで、少しの...
-
EXCELのVBAの中でMOD関数を使う...
-
エクセルVBAで#N/Aのようなエ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
UserForm1.Showでエラーになり...
-
String""から型'Double'への変...
-
VBAでfunctionを利用しようとし...
-
お助けください!VBAのファイル...
-
文字列内で括弧を使うには
-
実行時エラー 438 の解決策をお...
-
マクロで"#N/A"のエラー行を削...
-
On ErrorでエラーNoが0
-
エクセルVBA 「On Error GoTo...
-
VBA データ(特定値)のある最...
-
実行時エラー'-2147467259(8000...
-
【VBA】ワークブックを開く時に...
-
VBでSQL文のUPDATE構文を使った...
-
ACCESSで値を代入できないとは?
-
マクロの「SaveAs」でエラーが...
-
Excel vbaについての質問
-
インポート時のエラー「データ...
-
Filter関数を用いた結果、何も...
-
「実行時エラー '3167' レコー...
-
バッチファイルで、あるスクリ...
おすすめ情報