2

次のような何千ものエントリ(メッシュのノード)を含むテキスト ファイルがあります。

7.40000000000060391E+01   7.40000866410523770E+00    
1.05000000970718801E+01   6.40000007900613273E+01
2.40500000000000321E+02   2.40000000428227065E+00   
6.00000000000000000E+00   3.70000085530326430E+01   
7.40000019596598406E+01   6.40000000000000000E+01
3.10000144967919340E+01   1.92000112854581857E+01
6.40000000000000000E+01   6.40004500000000000E+01

私のエントリのいくつかに、削除したい小さなエラーがあります。テキストパッドを使用しています。トリプルゼロを見つけて他のすべての10進数をゼロに設定するまで、最初の数字を保持したいと思います. 上記の例は次のようになります。

7.40000000000000000E+01   7.40000000000000000E+00    
1.05000000000000000E+01   6.40000000000000000E+01
2.40500000000000000E+02   2.40000000000000000E+00   
6.00000000000000000E+00   3.70000000000000000E+01   
7.40000000000000000E+01   6.40000000000000000E+01
3.10000000000000000E+01   1.92000000000000000E+01
6.40000000000000000E+01   6.40000000000000000E+01

なにか提案を?ありがとうアルベルト

4

2 に答える 2

1

近くに JGSoft または .NET エンジンがない場合は、regexhero.net を試すことができます。.NET を利用したオンライン正規表現テスター です。

優れたTimの提案に基づいてデモを作成しました。

あなたはできる:

  • エントリをすばやくカット アンド ペーストする
  • それらをregexheroで変更してもらいます
  • 次に、結果をカットアンドペーストしてエディターに戻します

注:私は regexhero とは何の関係もありません :)

于 2014-02-17T22:05:19.740 に答える
1

興味深い問題です。String.replace()これは、正規表現とコールバック関数の置換値を持つメソッドを使用して、JavaScript で簡単に解決できます。最初に、仮数部の 3 つの連続するゼロ桁の後にゼロ以外の桁がある高精度浮動小数点数に一致する正規表現を作成する必要があります。これは、Python フリースペース モードでコメント付きで記述された正規表現です。

切り捨てられる数値に一致する正規表現:

re_truncatablebleFloat = re.compile(r"""
    # Match real/float number having form: 1.23450009012345678E+12
    \b             # Anchor to word boundary.
    (              # $1: Part to be preserved.
      \d+\.        # Integer portion and dot.
      [1-9]*       # Zero or more non-zero decimal digits.
      (?:          # Zero or more significant zeros.
        0          # Allow a zero digit, but only
        (?!00)     # if not start of a triple 000.
        [1-9]*     # Zero or more non-zero decimal digits.
      )*           # Zero or more significant zeros.
      000+         # Three or more zeros mark end of first part.
    )              # End $1: Part to be preserved.
    ([1-9]\d*)     # $2: Mantissa digits to be zeroed out.
    ([Ee][+-]\d+)  # $3: Well formed exponent.
    \b             # Anchor to word boundary.
    """, re.VERBOSE)

この正規表現は、変更が必要な float のみに一致することに注意してください。これは、数値の最初の部分をキャプチャ グループでキャプチャし$1、ゼロにする桁をグループでキャプチャ$2し、最後に指数をグループでキャプチャし$3ます。

テキストを修正する JavaScript 関数:

以下は、コールバック関数で上記の正規表現を使用して目前の問題を解決する、テスト済みの JavaScript 関数です。

function processText(text) {
    var re = /\b(\d+\.[1-9]*(?:0(?!00)[1-9]*)*000+)([1-9]\d*)([Ee][+-]\d+)\b/g;
    return text.replace(re,
        function(m0, m1, m2, m3){
            m2 = m2.replace(/[1-9]/g, '0');
            return m1 + m2 + m3;
        });
}

単一ページのスタンドアロン Web アプリケーション ソリューション:

以下は、上記の JavaScript 機能を組み込んだスタンドアロンの Web ページです。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head><title>Process Text 20140217_1300</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css" media="screen">
    body {margin: 2em; color:#333; background:#DDB;}
    h1, p {font-family: monospace; text-align: center;}
    textarea {width: 99%;}
</style>
<script type="text/javascript">/* <![CDATA[ */
// Process the input text.
function processText(text) {
    var re = /\b(\d+\.[1-9]*(?:0(?!00)[1-9]*)*000+)([1-9]\d*)([Ee][+-]\d+)\b/g;
    return text.replace(re,
        function(m0, m1, m2, m3){
            m2 = m2.replace(/[1-9]/g, '0');
            return m1 + m2 + m3;
        });
}
/* Read input, process, then write to output */
function handleOnclick() {
    var el_in  = document.getElementById('inbox'),
        el_out = document.getElementById('outbox');
    el_out.value = processText(el_in.value);
    return false;
} /* ]]> */</script>
</head><body>
<h1>Process Text</h1>
<form action="" method="get">
<h2>Input:</h2>
<p>
    <textarea id="inbox" name="inbox" rows="10" cols="80"></textarea>
    <input type="button" id="process" name="process" value="Process"
        onclick="return handleOnclick();"/>
</p>
<h2>Output:</h2>
<p>
    <textarea id="outbox" name="outbox" rows="10" cols="80"></textarea>
Note: Line endings may not be preserved! (i.e.
LF may be changed to CRLF or vice-verse)
</p>
</form>
</body></html>

これを HTML ファイルとしてデスクトップに保存し、お気に入りのブラウザで開くだけです。外部リソースを必要とせず、同様の問題を解決するために簡単に変更/再利用できます。

ハッピー正規表現!

于 2014-02-17T22:57:25.583 に答える