<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>IMLOG10 &#8211; biz-tactics</title>
	<atom:link href="https://mashukabu.com/tag/imlog10/feed/" rel="self" type="application/rss+xml" />
	<link>https://mashukabu.com</link>
	<description></description>
	<lastBuildDate>Tue, 28 Apr 2026 14:24:03 +0000</lastBuildDate>
	<language>ja</language>
	<sy:updatePeriod>
	hourly	</sy:updatePeriod>
	<sy:updateFrequency>
	1	</sy:updateFrequency>
	<generator>https://wordpress.org/?v=6.9.4</generator>

<image>
	<url>https://mashukabu.com/wp-content/uploads/2022/04/cropped-site-icon-32x32.png</url>
	<title>IMLOG10 &#8211; biz-tactics</title>
	<link>https://mashukabu.com</link>
	<width>32</width>
	<height>32</height>
</image> 
	<item>
		<title>スプレッドシートのIMLOG10関数の使い方｜複素数の常用対数を一発計算</title>
		<link>https://mashukabu.com/spreadsheet-imlog10-function/</link>
					<comments>https://mashukabu.com/spreadsheet-imlog10-function/#respond</comments>
		
		<dc:creator><![CDATA[まっしゅ]]></dc:creator>
		<pubDate>Tue, 28 Apr 2026 14:24:03 +0000</pubDate>
				<category><![CDATA[Googleスプレッドシート]]></category>
		<category><![CDATA[IMLOG10]]></category>
		<category><![CDATA[エンジニアリング関数]]></category>
		<category><![CDATA[スプレッドシート]]></category>
		<category><![CDATA[対数]]></category>
		<category><![CDATA[複素数]]></category>
		<guid isPermaLink="false">https://mashukabu.com/?p=6272</guid>

					<description><![CDATA[GoogleスプレッドシートのIMLOG10関数の使い方を解説。複素数（a+bi）の10を底とする常用対数を一発で求める基本構文、IMLN関数との関係（IMLN(z)/ln(10)）、主値の範囲、COMPLEX関数との連携、デシベル計算やpH解析など実務活用例、よくあるエラー対処法まで実例付きで紹介します。]]></description>
										<content:encoded><![CDATA[
<p>「スプレッドシートで複素数の常用対数を出したいけど、毎回IMLNをln(10)で割る式を書くのが面倒&#8230;」</p>



<p>スプレッドシートで複素数を扱う場面では、log₁₀(a+bi) の値が必要になることがありますよね。デシベル計算やpH解析、地震マグニチュードのように「桁数」を直感的に扱う分野では、自然対数より10を底とする常用対数のほうがしっくりきます。でも、毎回 IMLN とLNを組み合わせて分母にln(10)を入れるのは、数式が読みづらくなりがちです。</p>



<p>そんなときに頼りになるのがGoogleスプレッドシートのIMLOG10関数です。複素数を1つ渡すだけで「その複素数の10を底とする対数」を一発で返してくれますよ。デシベルやpHの数式が、ぐっとすっきりしますね。</p>



<p>ExcelのIMLOG10関数と完全互換なので、Excelファイルとやり取りする現場でも安心です。COMPLEX関数で作った複素数や、<a href="https://mashukabu.com/spreadsheet-imln-function/">IMLN関数</a>・<a href="https://mashukabu.com/spreadsheet-imlog2-function/">IMLOG2関数</a>と組み合わせた式からも、そのまま渡せますよ。</p>



<p>この記事では、スプレッドシートのIMLOG10関数の基本構文と実務での活用例を解説します。IMLNとの関係や、主値の範囲、よくあるエラーと対処法もしっかり紹介していきますね。</p>




  <div id="toc" class="toc tnt-number toc-center tnt-number border-element"><input type="checkbox" class="toc-checkbox" id="toc-checkbox-1" checked><label class="toc-title" for="toc-checkbox-1">目次</label>
    <div class="toc-content">
    <ol class="toc-list open"><li><a href="#toc1" tabindex="0">スプレッドシートのIMLOG10関数とは？</a></li><li><a href="#toc2" tabindex="0">IMLOG10関数の書き方（構文と引数）</a><ol><li><a href="#toc3" tabindex="0">基本構文</a></li><li><a href="#toc4" tabindex="0">引数の詳細</a></li></ol></li><li><a href="#toc5" tabindex="0">IMLOG10関数の基本的な使い方</a><ol><li><a href="#toc6" tabindex="0">文字列で複素数を直接指定する</a></li><li><a href="#toc7" tabindex="0">負の実数の対数を計算する</a></li><li><a href="#toc8" tabindex="0">セル参照で複素数を指定する</a></li><li><a href="#toc9" tabindex="0">COMPLEX関数と組み合わせる</a></li><li><a href="#toc10" tabindex="0">ARRAYFORMULAで複数行を一括処理する</a></li></ol></li><li><a href="#toc11" tabindex="0">IMLOG10関数の実務活用例</a><ol><li><a href="#toc12" tabindex="0">活用例1: デシベル（dB）計算</a></li><li><a href="#toc13" tabindex="0">活用例2: ボード線図のデータを作る</a></li><li><a href="#toc14" tabindex="0">活用例3: IMLN関数との関係を確認する</a></li><li><a href="#toc15" tabindex="0">活用例4: pH・化学濃度の桁数表示</a></li><li><a href="#toc16" tabindex="0">活用例5: 地震マグニチュードや天文等級の桁スケール</a></li></ol></li><li><a href="#toc17" tabindex="0">IMLOG10関数とCOMPLEX関数群の関係</a></li><li><a href="#toc18" tabindex="0">IMLOG10関数のよくあるエラーと対処法</a><ol><li><a href="#toc19" tabindex="0">#NUM! エラー（複素数の形式エラー、または z=0）</a></li><li><a href="#toc20" tabindex="0">#VALUE! エラー（引数の型エラー）</a></li><li><a href="#toc21" tabindex="0">主値の範囲を超えた角度を期待してしまう問題</a></li><li><a href="#toc22" tabindex="0">IFERRORでまとめてエラーを吸収する</a></li></ol></li><li><a href="#toc23" tabindex="0">IMLOG10関数とExcelの互換性</a></li><li><a href="#toc24" tabindex="0">複素数関連の関数一覧</a></li><li><a href="#toc25" tabindex="0">まとめ</a></li></ol>
    </div>
  </div>

<h2 class="wp-block-heading"><span id="toc1">スプレッドシートのIMLOG10関数とは？</span></h2>



<p>GoogleスプレッドシートのIMLOG10関数は、複素数の10を底とする対数（log₁₀(z)）を返す関数です。エンジニアリング関数（電気・物理・工学系の計算で使う関数群）のひとつに分類されますよ。</p>



<p>読み方は「イマジナリー・ログ・テン」または「アイエム・ログ・テン」です。英語の「imaginary（虚数の）」と「logarithm base 10（10を底とする対数）」を組み合わせた名前ですね。複素数「a+bi」の常用対数を、複素数として返してくれるのが役割です。</p>



<p>複素数の常用対数は、自然対数を ln(10) で割り算した形で定義できます。具体的な式は次のとおりですよ。</p>



<pre class="wp-block-code"><code>log10(a+bi) = ln(a+bi) / ln(10)
           = log10(|a+bi|) + i × arg(a+bi) / ln(10)
           = log10(√(a²+b²)) + i × atan2(b, a) / ln(10)</code></pre>



<p>実部は「絶対値の常用対数」、虚部は「偏角を ln(10) で割った値」となり、結果も複素数で返るのが特徴ですね。ln(10) は約2.3026なので、IMLN の結果に対しておよそ0.4343倍したものに相当します。</p>



<figure class="wp-block-table"><table><thead><tr><th>複素数（z）</th><th>IMLOG10(z)の結果</th><th>内部計算</th></tr></thead><tbody><tr><td>1+0i</td><td>0</td><td>log10(1) = 0</td></tr><tr><td>10+0i</td><td>1+0i</td><td>log10(10) = 1</td></tr><tr><td>100+0i</td><td>2+0i</td><td>log10(100) = 2</td></tr><tr><td>1000+0i</td><td>3+0i</td><td>log10(1000) = 3</td></tr><tr><td>-1+0i</td><td>0+1.3644i</td><td>log10(1) + i×π/ln(10)</td></tr><tr><td>0+1i</td><td>0+0.6822i</td><td>log10(1) + i×π/(2ln(10))</td></tr><tr><td>1+1i</td><td>0.1505+0.6822i</td><td>log10(√2) + i×(π/4)/ln(10)</td></tr></tbody></table></figure>



<p>IMLOG10関数を使えば、この表の右側にある「複素数の常用対数」をサクッと取り出せます。Excelとの互換性も完璧で、Excel 2007以降のすべてのバージョンに対応していますよ。</p>



<p>複素数の常用対数は、デシベル計算・pH/化学濃度の解析・地震マグニチュード・周波数応答のボード線図・天文学の等級など、「桁数」のスケールが必要な場面で活躍します。「10倍するごとに1ずつ増える」という直感的なスケールが欲しい場面で、欠かせない基礎パーツですね。</p>



<h2 class="wp-block-heading"><span id="toc2">IMLOG10関数の書き方（構文と引数）</span></h2>



<h3 class="wp-block-heading"><span id="toc3">基本構文</span></h3>



<pre class="wp-block-code"><code>=IMLOG10(複素数)</code></pre>



<p>引数は1つで、常用対数を取りたい複素数を渡す形ですよ。</p>



<h3 class="wp-block-heading"><span id="toc4">引数の詳細</span></h3>



<figure class="wp-block-table"><table><thead><tr><th>引数</th><th>必須/任意</th><th>説明</th></tr></thead><tbody><tr><td>複素数（inumber）</td><td>必須</td><td>常用対数を計算する複素数。文字列またはセル参照で指定する</td></tr></tbody></table></figure>



<p>引数には「&#8221;1+2i&#8221;」や「&#8221;1+2j&#8221;」のような複素数文字列を直接渡せます。COMPLEX関数（実数と虚数から複素数を作成する関数）の結果や、複素数が入ったセルの参照も指定できますよ。</p>



<p>虚数単位は小文字の「i」または「j」のどちらでも受け付けます。数学では「i」、電気工学では「j」が使われる慣習ですね。IMLOG10関数はどちらでも同じように動作してくれます。</p>



<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow"><p><strong>TIP</strong></p><p>IMLOG10が返す虚部の範囲は -π/ln(10) < θ ≤ π/ln(10)、おおよそ -1.3644 < θ ≤ 1.3644 です。これは <a href="https://mashukabu.com/spreadsheet-imln-function/">IMLN関数</a> の主値（-π〜π）を ln(10) で割った値に相当しますよ。覚えておきましょう。</p></blockquote>



<p>引数に正の実数だけを渡せば、通常のLOG10関数と同じ結果になります。「IMLOG10(&#8220;1000&#8221;)」も「LOG10(1000)」もどちらも3ですね。違いは戻り値が複素数文字列になるか実数になるかだけですよ。</p>



<h2 class="wp-block-heading"><span id="toc5">IMLOG10関数の基本的な使い方</span></h2>



<h3 class="wp-block-heading"><span id="toc6">文字列で複素数を直接指定する</span></h3>



<p>複素数文字列をそのまま引数に渡してみましょう。</p>



<pre class="wp-block-code"><code>=IMLOG10(&quot;1+1i&quot;)</code></pre>



<p>結果は「0.150514997831991+0.682188176920921i」になります。実部はlog₁₀(√2)≈0.1505、虚部は(π/4)/ln(10)≈0.6822ですね。</p>



<p>正の実部だけの複素数を渡すと、通常のLOG10関数と同じ結果になります。</p>



<pre class="wp-block-code"><code>=IMLOG10(&quot;1000&quot;)
=IMLOG10(&quot;1000+0i&quot;)</code></pre>



<p>どちらも結果は約「3+0i」、つまり log₁₀(1000) = 3 ですよ。実数の世界の常用対数と一致しますね。</p>



<p>純虚数を渡すと、結果は実部0で虚部が±π/(2ln(10))になります。</p>



<pre class="wp-block-code"><code>=IMLOG10(&quot;0+1i&quot;)
=IMLOG10(&quot;0-1i&quot;)</code></pre>



<p>前者は「0+0.6822&#8230;i」、後者は「0-0.6822&#8230;i」になりますよ。複素平面の縦軸に乗っている純虚数の偏角が、±π/(2ln(10))として返ってきますね。</p>



<h3 class="wp-block-heading"><span id="toc7">負の実数の対数を計算する</span></h3>



<p>実数の世界では「負の数の対数は計算できない」とされますよね。複素数まで広げると、IMLOG10はちゃんと値を返してくれます。</p>



<pre class="wp-block-code"><code>=IMLOG10(&quot;-1&quot;)</code></pre>



<p>結果は「0+1.36437635384184i」になりますよ。実部は0、虚部はπ/ln(10)となります。これは「-1 = 1 × e^(iπ)」を10底に直したものですね。LOG10(-1) はエラーになりますが、IMLOG10 なら計算できる点が便利なところです。</p>



<h3 class="wp-block-heading"><span id="toc8">セル参照で複素数を指定する</span></h3>



<p>実務ではセルに入った複素数を扱う場面が多いですよね。A2に「1+1i」が入っている場合は次のように書きます。</p>



<pre class="wp-block-code"><code>=IMLOG10(A2)</code></pre>



<p>結果は「0.1505&#8230;+0.6822&#8230;i」になります。セル参照を渡すだけで、入っている複素数の常用対数を取り出せますよ。</p>



<h3 class="wp-block-heading"><span id="toc9">COMPLEX関数と組み合わせる</span></h3>



<p><a href="https://mashukabu.com/spreadsheet-complex-function/">COMPLEX関数</a>で作った複素数を、その場でIMLOG10に渡すこともできます。</p>



<pre class="wp-block-code"><code>=IMLOG10(COMPLEX(1, 1))</code></pre>



<p>結果は「0.1505&#8230;+0.6822&#8230;i」、つまり「IMLOG10(&#8220;1+1i&#8221;)」と同じですね。COMPLEX(1, 1)が内部で「1+1i」を作り、IMLOG10関数がその常用対数を返してくれます。</p>



<p>数値で実部と虚部を渡したいときに便利な書き方ですよ。</p>



<h3 class="wp-block-heading"><span id="toc10">ARRAYFORMULAで複数行を一括処理する</span></h3>



<p>複素数のリストに対して一気に常用対数の列を作りたい場面もありますよね。そんなときはARRAYFORMULA関数（数式を範囲全体に展開する関数）と組み合わせます。</p>



<pre class="wp-block-code"><code>=ARRAYFORMULA(IMLOG10(A2:A10))</code></pre>



<p>A列の複素数を順番に常用対数に変換して、対応する結果をB列に一発で展開できますよ。デシベル計算やpH解析を一括処理するときに重宝しますね。</p>



<h2 class="wp-block-heading"><span id="toc11">IMLOG10関数の実務活用例</span></h2>



<h3 class="wp-block-heading"><span id="toc12">活用例1: デシベル（dB）計算</span></h3>



<p>電気・音響工学では、信号の比をデシベルで表しますよね。電圧比なら 20×log₁₀(V₁/V₀)、電力比なら 10×log₁₀(P₁/P₀) という公式です。複素フェーザの比をそのままデシベル化したい場面で IMLOG10 が活躍しますよ。</p>



<p>A列に複素電圧の比（V₁/V₀）が並んでいるとしましょう。</p>



<pre class="wp-block-code"><code>B2: =IMLOG10(A2)            ← 複素常用対数
C2: =IMREAL(B2)             ← log10(|V1/V0|)
D2: =20*C2                  ← 電圧ゲイン（dB）</code></pre>



<p>D列がデシベルでの利得です。位相情報も保持したまま大きさをデシベル化できるので、ボード線図の数値テーブルを作るときに便利ですね。</p>



<h3 class="wp-block-heading"><span id="toc13">活用例2: ボード線図のデータを作る</span></h3>



<p>周波数応答 H(jω) = R + jX を、周波数ごとにゲインと位相に分解する作業もすっきり書けますよ。</p>



<pre class="wp-block-code"><code>A2: =COMPLEX(R, X)              ← 周波数 ω での H(jω)
B2: =IMLOG10(A2)                ← 複素常用対数
C2: =20*IMREAL(B2)              ← ゲイン（dB）
D2: =DEGREES(IMARGUMENT(A2))    ← 位相（度）</code></pre>



<p>C列がボード線図のゲイン軸、D列が位相軸の値になりますね。IMLOG10 を1つ挟むだけで、周波数応答からボード線図用のデータが整いますよ。</p>



<h3 class="wp-block-heading"><span id="toc14">活用例3: IMLN関数との関係を確認する</span></h3>



<p>IMLOG10関数は、内部的に「IMLN(z) ÷ ln(10)」と等価です。実際にスプレッドシートで確認してみましょう。</p>



<pre class="wp-block-code"><code>A2: =COMPLEX(1, 1)              ← z = 1+i
B2: =IMLOG10(A2)                ← 直接計算
C2: =IMDIV(IMLN(A2), COMPLEX(LN(10), 0))   ← IMLNから計算</code></pre>



<p>B2とC2の値は一致して「0.1505&#8230;+0.6822&#8230;i」になりますよ。IMLOG10は IMLN の結果を ln(10) で割った形と同じだと、数式レベルで確認できますね。底の変換公式を理解する勉強用にも使える書き方です。</p>



<h3 class="wp-block-heading"><span id="toc15">活用例4: pH・化学濃度の桁数表示</span></h3>



<p>化学では水素イオン濃度 [H⁺] から pH = -log₁₀([H⁺]) を求めますよね。シミュレーションで濃度を複素数として扱うケース（複素誘電率の解析など）でも、IMLOG10 で一気に処理できますよ。</p>



<pre class="wp-block-code"><code>A2: =COMPLEX(1E-7, 0)           ← [H+] = 1.0e-7
B2: =IMLOG10(A2)                ← 複素常用対数
C2: =-IMREAL(B2)                ← pH = -log10(|[H+]|)</code></pre>



<p>C2は7になります。中性のpHですね。実数だけならLOG10で十分ですが、複素誘電率や交流インピーダンスを介した解析パイプラインに乗せるときは、IMLOG10 で型を揃えると見通しが良くなりますよ。</p>



<h3 class="wp-block-heading"><span id="toc16">活用例5: 地震マグニチュードや天文等級の桁スケール</span></h3>



<p>地震マグニチュード（M = log₁₀(A) + 補正項）や、星の等級（m = -2.5×log₁₀(F)）のように、対数スケールで「桁」を扱う指標は身近にたくさんあります。観測値の補正に複素数振幅が混じる解析でも、IMLOG10 がそのまま使えますよ。</p>



<pre class="wp-block-code"><code>A2: =COMPLEX(1.0E5, 0)          ← 観測振幅 A
B2: =IMLOG10(A2)                ← 桁スケール
C2: =IMREAL(B2)                 ← log10(A) の実部</code></pre>



<p>A2が10万なら C2 は5になります。データ量が10倍になるごとに1ずつ増えるスケールが、シート上で直感的に確認できますね。複素数を扱わない単純なケースなら <code>=LOG10(A2)</code> でも構いません。複素数を含む解析パイプラインの中では、IMLOG10 で型を揃えるとシートが整いますよ。</p>



<h2 class="wp-block-heading"><span id="toc17">IMLOG10関数とCOMPLEX関数群の関係</span></h2>



<p>複素数を扱う関数群の中で、IMLOG10関数の位置づけを整理しておきましょう。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数</th><th>入力</th><th>出力</th><th>役割</th></tr></thead><tbody><tr><td><a href="https://mashukabu.com/spreadsheet-complex-function/">COMPLEX</a></td><td>実数 a, b</td><td>複素数 a+bi</td><td>複素数を作る</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imreal-function/">IMREAL</a></td><td>複素数 a+bi</td><td>実数 a</td><td>実部を取り出す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imaginary-function/">IMAGINARY</a></td><td>複素数 a+bi</td><td>実数 b</td><td>虚部を取り出す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imabs-function/">IMABS</a></td><td>複素数 a+bi</td><td>実数 √(a²+b²)</td><td>大きさを取り出す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imargument-function/">IMARGUMENT</a></td><td>複素数 a+bi</td><td>実数（ラジアン）</td><td>偏角を取り出す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imexp-function/">IMEXP</a></td><td>複素数 z</td><td>複素数 e^z</td><td>指数関数</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imln-function/">IMLN</a></td><td>複素数 z</td><td>複素数 ln(z)</td><td>自然対数</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imlog2-function/">IMLOG2</a></td><td>複素数 z</td><td>複素数 log₂(z)</td><td>2を底とする対数</td></tr><tr><td>IMLOG10</td><td>複素数 z</td><td>複素数 log₁₀(z)</td><td>10を底とする対数</td></tr><tr><td>IMPOWER</td><td>複素数 z, 実数 n</td><td>複素数 z^n</td><td>べき乗</td></tr></tbody></table></figure>



<p>IMLOG10関数とIMLN関数は「底の変換公式」でつながっています。「IMLOG10(z) = IMLN(z) / ln(10)」が数学的な関係ですよ。同様に <a href="https://mashukabu.com/spreadsheet-imlog2-function/">IMLOG2</a> は IMLN(z) / ln(2) と等価ですね。</p>



<p>たとえば定義式どおりに log₁₀(a+bi) を手動で組み立てると次のようになります。</p>



<pre class="wp-block-code"><code>=COMPLEX(LOG10(SQRT(IMREAL(A2)^2+IMAGINARY(A2)^2)), ATAN2(IMREAL(A2), IMAGINARY(A2))/LN(10))</code></pre>



<p>これはIMLOG10と同じ結果になりますが、絶対値と偏角を毎回手書きする必要がありますよね。IMLOG10を使えば1関数で済むので、数式が読みやすくなります。</p>



<h2 class="wp-block-heading"><span id="toc18">IMLOG10関数のよくあるエラーと対処法</span></h2>



<h3 class="wp-block-heading"><span id="toc19">#NUM! エラー（複素数の形式エラー、または z=0）</span></h3>



<p>複素数として認識できない文字列を渡したときや、ゼロを渡したときに発生します。</p>



<pre class="wp-block-code"><code>=IMLOG10(&quot;1+1I&quot;)     → #NUM!（大文字のIは不可）
=IMLOG10(&quot;1+1k&quot;)     → #NUM!（i・j以外は不可）
=IMLOG10(&quot;1 + 1i&quot;)   → #NUM!（途中の空白は不可）
=IMLOG10(&quot;0&quot;)        → #NUM!（log10(0)は定義されない）
=IMLOG10(&quot;0+0i&quot;)     → #NUM!（同上）</code></pre>



<p>対処法は2つあります。1つ目は、複素数文字列を必ず半角の「a+bi」または「a+bj」の形式にすることです。虚数単位は小文字限定なので、CapsLockがオンになっていないか確認してくださいね。</p>



<p>2つ目は、ゼロを渡さないことです。実数の世界でlog₁₀(0)が定義されないのと同じく、複素数の世界でも0の対数は計算できません。入力データに0が混じる可能性がある場合は、後述のIFERROR対策を入れておきましょう。</p>



<h3 class="wp-block-heading"><span id="toc20">#VALUE! エラー（引数の型エラー）</span></h3>



<p>引数に論理値やエラー値を渡したときに発生します。</p>



<pre class="wp-block-code"><code>=IMLOG10(TRUE)       → #VALUE!（論理値は不可）
=IMLOG10(#N/A)       → #VALUE!（エラー値は不可）</code></pre>



<p>対処法は、正しい複素数文字列または数値・セル参照を渡すことです。入力元のセルがエラーになっている場合は、そのエラーを先に解消する必要がありますよ。</p>



<h3 class="wp-block-heading"><span id="toc21">主値の範囲を超えた角度を期待してしまう問題</span></h3>



<p>IMLOG10が返す虚部は -π/ln(10) < θ ≤ π/ln(10)、つまり約 -1.3644 < θ ≤ 1.3644 の主値だけです。これは <a href="https://mashukabu.com/spreadsheet-imln-function/">IMLN関数</a> の主値 (-π, π] を ln(10) で割った値ですね。</p>



<pre class="wp-block-code"><code>=IMLOG10(&quot;0-1i&quot;)     → 0-0.6822i（-π/(2ln10)）</code></pre>



<p>この複素数 -i は「3π/2 ラジアン回転した点」とも見なせますが、IMLOG10 はそのうち主値（-π/2 を ln(10) で割った値）を返します。連続的に偏角を追跡したい場面では、後段で「アンラップ処理」を実装する必要がある点に注意してくださいね。</p>



<h3 class="wp-block-heading"><span id="toc22">IFERRORでまとめてエラーを吸収する</span></h3>



<p>入力データの信頼性が低い場合や、ゼロが混じる可能性がある場合に備えておきたいですよね。そんなときはIFERROR関数（エラー時に代替値を返す関数）で包んでおきましょう。シート全体の集計が止まらず安心です。</p>



<pre class="wp-block-code"><code>=IFERROR(IMLOG10(A2), &quot;計算不可&quot;)</code></pre>



<p>エラー時にメッセージを返すようにしておけば、安心して大量データに適用できますよ。</p>



<h2 class="wp-block-heading"><span id="toc23">IMLOG10関数とExcelの互換性</span></h2>



<p>GoogleスプレッドシートのIMLOG10関数は、ExcelのIMLOG10関数と仕様が完全に一致しています。構文・引数・戻り値の形式・主値の範囲・エラー条件まで同じですよ。</p>



<p>ExcelファイルをGoogleスプレッドシートで開いてもIMLOG10関数はそのまま動作します。逆にスプレッドシートで作った数式をExcelで開いても問題ありませんね。</p>



<p>ExcelのIMLOG10関数は、Excel 2007以降のすべてのバージョンで利用できます。Microsoft 365、Excel for Mac、Excel Online でも同じように使えますよ。古いExcelファイルとの互換性も心配いりません。</p>



<h2 class="wp-block-heading"><span id="toc24">複素数関連の関数一覧</span></h2>



<p>IMLOG10関数と一緒に使うことが多い、複素数関連の関数をまとめました。</p>



<figure class="wp-block-table"><table><thead><tr><th>関数名</th><th>機能</th></tr></thead><tbody><tr><td><a href="https://mashukabu.com/spreadsheet-complex-function/">COMPLEX</a></td><td>実数と虚数から複素数を作成する</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imreal-function/">IMREAL</a></td><td>複素数の実数係数を返す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imaginary-function/">IMAGINARY</a></td><td>複素数の虚数係数を返す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imabs-function/">IMABS</a></td><td>複素数の絶対値（大きさ）を返す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imargument-function/">IMARGUMENT</a></td><td>複素数の偏角（角度）をラジアンで返す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imconjugate-function/">IMCONJUGATE</a></td><td>共役複素数を返す</td></tr><tr><td>IMSUM</td><td>複素数の合計（足し算）を返す</td></tr><tr><td>IMSUB</td><td>複素数の差（引き算）を返す</td></tr><tr><td>IMPRODUCT</td><td>複素数の積（掛け算）を返す</td></tr><tr><td>IMDIV</td><td>複素数の商（割り算）を返す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imexp-function/">IMEXP</a></td><td>複素数の指数関数（eべき乗）を返す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imln-function/">IMLN</a></td><td>複素数の自然対数を返す</td></tr><tr><td><a href="https://mashukabu.com/spreadsheet-imlog2-function/">IMLOG2</a></td><td>複素数の2を底とする対数を返す</td></tr><tr><td>IMLOG10</td><td>複素数の10を底とする対数を返す</td></tr><tr><td>IMPOWER</td><td>複素数のべき乗を返す</td></tr><tr><td>IMSQRT</td><td>複素数の平方根を返す</td></tr></tbody></table></figure>



<p>IMLOG10関数は、これら複素数関数群の中で「常用対数」を担う基本関数ですね。COMPLEXで複素数を作り、IMLOG10で常用対数値を求めるのが基本の流れです。最後はIMREAL・IMAGINARYで実部と虚部に分けて可視化しましょう。デシベル計算やボード線図、pH解析のシートを軽快に組み立てられますよ。</p>



<h2 class="wp-block-heading"><span id="toc25">まとめ</span></h2>



<p>GoogleスプレッドシートのIMLOG10関数は、複素数の10を底とする対数（log₁₀(z)）を返す関数です。デシベル計算・ボード線図・pH解析・地震マグニチュード・天文等級など、「10倍ごとに1増える」直感的な桁スケールが欲しい場面で欠かせない関数ですよ。</p>



<ul class="wp-block-list"><li>構文は <code>=IMLOG10(複素数)</code> で複素数を1つ渡すだけ</li><li>「log10(a+bi) = ln(a+bi) / ln(10)」が内部計算式</li><li>実部は絶対値の常用対数、虚部は偏角を ln(10) で割った値になる</li><li>「a+bi」と「a+bj」のどちらの表記もそのまま受け付ける</li><li>虚部の主値は -π/ln(10) < θ ≤ π/ln(10)（約 -1.3644 〜 1.3644）</li><li>正の実部だけの複素数を渡すと通常のLOG10と同じ結果になる</li><li>「log10(-1)」も計算でき、結果は 0+(π/ln(10))i になる</li><li>COMPLEX関数の結果やセル参照、複素数演算の結果も渡せる</li><li>ARRAYFORMULAで複数の複素数を一括処理できる</li><li>IMLN関数とは「IMLOG10(z) = IMLN(z) / ln(10)」の関係</li><li>z=0 を渡すと #NUM! エラー（log10(0)は定義されない）</li><li>大文字の「I」「J」やi・j以外の単位は #NUM! エラー</li><li>論理値やエラー値を渡すと #VALUE! エラー</li><li>ExcelのIMLOG10関数と完全互換（Excel 2007以降）</li></ul>



<p>複素数の常用対数が必要になったら、IMLOG10関数の出番ですよ。COMPLEX関数で複素数を作り、IMLOG10で対数を取りましょう。最後にIMREAL・IMAGINARYで実部と虚部に分解すれば、デシベル計算やボード線図、pH解析のシートを軽快に組み立てられますね。</p>
]]></content:encoded>
					
					<wfw:commentRss>https://mashukabu.com/spreadsheet-imlog10-function/feed/</wfw:commentRss>
			<slash:comments>0</slash:comments>
		
		
			</item>
	</channel>
</rss>
