工学計算(Microsoft Excel)
エンジニアリング環境では、「正規化」する必要があることは珍しくありません
何らかの方法で数字。たとえば、7340が7.34として表され、73400が73.4として表されるように、10 ^ 3の倍数に正規化された数値を表示する必要がある場合があります。
Excelでは、カスタムの数値形式を使用して、数値の表示を10 ^ 3の倍数に正規化する科学的記数法で情報を表現することができます。これを行うには、次の手順に従います。
。フォーマットするセルを選択します。
。 「フォーマット」メニューから「セル」オプションを選択します。 Excelに[セルの書式設定]ダイアログボックスが表示されます。
。 [番号]タブが選択されていることを確認してください。
。フォーマットカテゴリのリストで、[カスタム]を選択します。 (図1を参照)
。 [タイプ]ボックスに、形式として## 0.0E +0を入力します。 (これにより、小数点以下1桁の数値のみが提供されます。さらに必要な場合は、小数点以下のゼロの数を増やしてください。)
。 [OK]をクリックします。
これで、セルに7340などの数値を入力すると、Excelはそれを7.3E +3と表示します。セル形式の入力方法により、Eの後の部分は常に3の倍数になります。
これは問題ありませんが、セルに7.3だけを入れてから、隣接するセルに単位を付けたメートル法の接頭辞(キログラムなど)が必要な場合はどうでしょうか。これはもう少し複雑ですが、数式を使用して実行できます。たとえば、セルA2に元の番号があり、セルB2に正規化された番号が必要であり、セルC2にメティックプレフィックスとユニット名があるとします。セルB2に次の数式を入力するだけです。
=IF(OR(A2>=1,A2<=-1),SIGN(A2)(ABS(A2)/(10^(3INT(LOG(ABS(A2))/3)))), IF(A2=0,0,SIGN(A2)(ABS(A2)10^(-3*INT(LOG(ABS(A2))/3)))))
使用している単位がfooと呼ばれる虚数単位であるとすると、セルC2では、次のように別の数式を使用します。
=IF(OR(A2>=1, A2<=-1),CHOOSE(INT(LOG(ABS(A2))/3)+1, "Foos", "Kilofoos", "Megafoos", "Gigafoos", "Terafoos", "Petafoos", "Exafoos"), IF(A2=0,"",CHOOSE(INT(-LOG(ABS(A2))/3)+1, "Millifoos", "Microfoos", "Nanofoos", "Picofoos", "Femtofoos", "Attofoos")))
これらの式は少し長いように見えるかもしれません、そしてそれらはそうです。ただし、約-9.99999E-18から9.99999E +20までの任意の数で機能します。
たとえば、セルA2に番号.000125を入力すると、セルB2には125が含まれ、セルC2にはMillifooが含まれます。
ブックでこれらのような長い数式を使用したくない場合は、いくつかのVBA関数を開発してそのトリックを実行できます。
次の関数MySciNumは、正規化された数値を返します。したがって、セルB2で= MySciNum(A2)を使用して、上記と同じ結果を取得します。
Function MySciNum(BaseNum As Double) As Double Select Case BaseNum Case Is >= 1 While Abs(BaseNum) > 1000 BaseNum = BaseNum / 1000 Wend Case 0 'Do nothing Case Else While Abs(BaseNum) < 1 BaseNum = BaseNum * 1000 Wend End Select MySciNum = BaseNum End Function
この関数は数値のみを返します。適切なメトリックプレフィックスを持つ単位を返すには、次の関数を使用します。あなたがする必要があるのはそれにセル参照と単一のユニットの名前を渡すことです。
たとえば、= MySciPre(A2、 “foo”)を使用できます。マクロは次のとおりです。
Function MySciPre(BaseNum As Double, Unit As String) As String Dim OrigNum As Double Dim Pref As Integer Dim Temp As String Pref = 0 OrigNum = BaseNum Select Case BaseNum Case Is >= 1 While Abs(BaseNum) > 1000 BaseNum = BaseNum / 1000 Pref = Pref + 1 Wend Case 0 Pref = 99 Case Else While Abs(BaseNum) < 1 BaseNum = BaseNum * 1000 Pref = Pref - 1 Wend End Select Select Case Pref Case -6 Temp = "atto" & Unit Case -5 Temp = "femto" & Unit Case -4 Temp = "pico" & Unit Case -3 Temp = "nano" & Unit Case -2 Temp = "micro" & Unit Case -1 Temp = "milli" & Unit Case 0 Temp = Unit Case 1 Temp = "kilo" & Unit Case 2 Temp = "mega" & Unit Case 3 Temp = "giga" & Unit Case 4 Temp = "tera" & Unit Case 5 Temp = "peta" & Unit Case 6 Temp = "exa" & Unit Case Else Temp = "" End Select If Len(Temp) > 0 Then Temp = LCase(Temp) Temp = UCase(Left(Temp, 1)) & Mid(Temp, 2) If Abs(OrigNum) <> 1 Then Temp = Temp & "s" End If MySciPre = Temp End Function
注:
このページ(または_ExcelTips_サイトの他のページ)で説明されているマクロの使用方法を知りたい場合は、役立つ情報を含む特別なページを用意しました。
_ExcelTips_は、費用効果の高いMicrosoftExcelトレーニングのソースです。
このヒント(2928)は、Microsoft Excel 97、2000、2002、および2003に適用されます。Excel(Excel 2007以降)のリボンインターフェイス用のこのヒントのバージョンは、次の場所にあります。