WorksheetFunction メソッド (Excel)WorksheetFunction.OddLYield method (Excel)

最終期の日数が半端な証券の利回りを返します。Returns the yield of a security that has an odd (short or long) last period.


OddLYield(Arg1Arg2Arg3Arg4Arg5Arg6Arg7Arg8)expression.OddLYield (Arg1, Arg2, Arg3, Arg4, Arg5, Arg6, Arg7, Arg8)

: WorksheetFunction オブジェクトを表す変数。expression A variable that represents a WorksheetFunction object.


名前Name 必須 / オプションRequired/Optional データ型Data type 説明Description
Arg1Arg1 必須Required バリアント型Variant 受渡日: 証券の受渡日を指定します。Settlement - the security's settlement date. 受渡日とは、発行日以降に証券が買い手に引き渡される日付です。The security settlement date is the date after the issue date when the security is traded to the buyer.
Arg2Arg2 必須Required バリアント型Variant 満期日: 証券の満期日を指定します。Maturity - the security's maturity date. 満期日とは、証券の支払期日です。The maturity date is the date when the security expires.
Arg3Arg3 必須Required バリアント型Variant 最終利払日: 証券の最後の利払日を指定します。Last_interest - the security's last coupon date.
Arg4Arg4 必須Required バリアント型Variant 利率: 証券の利率を指定します。Rate - the security's interest rate.
Arg5Arg5 必須Required バリアント型Variant 現在価値: 証券の価格を指定します。Pr - the security's price.
Arg6Arg6 必須Required バリアント型Variant 償還価額: 額面 $ 100 に対する証券の償還額を指定します。Redemption - the security's redemption value per $100 face value.
Arg7Arg7 必須Required バリアント型Variant 頻度: 年間の利息支払回数を指定します。Frequency - the number of coupon payments per year. 年 1 回の場合は頻度 = 1、年 2 回の場合は頻度 = 2、四半期ごとの場合は頻度 = 4 を指定します。For annual payments, frequency = 1; for semiannual, frequency = 2; for quarterly, frequency = 4.
Arg8Arg8 省略可能Optional VariantVariant 基準: 計算に使用する基準日数を示す数値を指定します。Basis - the type of day count basis to use.

戻り値Return value

倍精度浮動小数点型 (Double)Double



日付は、DATE 関数を使って入力するか、他の数式または他の関数の結果を指定します。Dates should be entered by using the DATE function, or as results of other formulas or functions. たとえば、2008 年 5 月 23 日を入力する場合は、DATE (2008,5,23) を使用します。For example, use DATE(2008,5,23) for the 23rd day of May, 2008. 日付を文字列として入力した場合、エラーが発生することがあります。Problems can occur if dates are entered as text.

次の表では、 _Arg8_に使用できる値について説明します。The following table describes the values that can be used for Arg8.

基準Basis 基準日数 (月/年)Day count basis
0 または省略0 or omitted 30 日/360 日 (NASD 方式)US (NASD) 30/360
1-d1 実際の日数/実際の日数Actual/actual
pbm-22 実際の日数/360 日Actual/360
1/33 実際の日数/365 日Actual/365
2/44 30 日/360 日 (ヨーロッパ方式)European 30/360

Excel では、日付は集計に使用できるようにシリアル値として格納されます。Microsoft Excel stores dates as sequential serial numbers so they can be used in calculations. 既定では、1900 年 1 月 1 日のシリアル値は 1、2008 年 1 月 1 日は 1900 年 1 月 1 日から 39,448 日後であるためシリアル値は 39,448 になります。By default, January 1, 1900 is serial number 1, and January 1, 2008 is serial number 39448 because it is 39,448 days after January 1, 1900. Macintosh 版の Excel では、既定とは異なる日付システムが使用されます。Microsoft Excel for the Macintosh uses a different date system as its default.


Visual Basic for Applications (VBA) では、Excel と異なる方法でシリアル日付が計算されます。Visual Basic for Applications (VBA) calculates serial dates differently than Excel. VBA では、シリアル日付値 1 は 1900 年 1 月 1 日ではなく、1899 年 12 月 31 日に該当します。In VBA, serial number 1 is December 31, 1899, rather than January 1, 1900.

受渡日とは、債券などの証券の売買代金を決済した日付です。The settlement date is the date a buyer purchases a coupon, such as a bond. 満期日とは、証券の支払期日です。The maturity date is the date when a coupon expires. たとえば、2008 年 1 月 1 日に発行された 30 年債券を、発行日の 6 か月後に購入したとします。For example, suppose a 30-year bond is issued on January 1, 2008, and is purchased by a buyer six months later. この債券は、発行日が 2008 年 1 月 1 日、受渡日が 2008 年 7 月 1 日になり、満期日は、発行日の 2008 年 1 月 1 日から 30 年後の 2038 年 1 月 1 日になります。The issue date would be January 1, 2008, the settlement date would be July 1, 2008, and the maturity date would be January 1, 2038, which is 30 years after the January 1, 2008, issue date.

受渡日、満期日、最終利払日、基準に整数以外の値を指定すると、小数点以下が切り捨てられます。Settlement, maturity, last_interest, and basis are truncated to integers.

受渡日、満期日、または最終利払日が有効な日付ではない場合、 OddLYieldは #VALUE を返します。If settlement, maturity, or last_interest is not a valid date, OddLYield returns the #VALUE! が返されます。error value.

Rate < 0 または pr ≤0である場合、 OddLYieldは #NUM を返します。If rate < 0 or if pr ≤ 0, OddLYield returns the #NUM! が返されます。error value.

Basis < 0 または basis > 4 の場合、 OddLYieldは #NUM を返します。If basis < 0 or if basis > 4, OddLYield returns the #NUM! が返されます。error value.

次の日付条件を満たす必要があります。それ以外の場合、 OddLYieldは #NUM を返します。The following date condition must be satisfied; otherwise, OddLYield returns the #NUM! エラー値: 満期日 > 決済 > 最終利払日。error value: maturity > settlement > last_interest.

OddLYieldは、次のように計算されます。OddLYield is calculated as follows:



  • Ai = 半端期間内の i 番目または最後の準利払期間における償還日数を計算する前に、最後の利息の日付から順に数えます。Ai = number of accrued days for the ith, or last, quasi-coupon period within odd period counting forward from last interest date before redemption.
  • DCi = 実際の利息期間の長さで区切られた、i 番目または最後の擬似利払期間で数えられた日数。DCi = number of days counted in the ith, or last, quasi-coupon period as delimited by the length of the actual coupon period.
  • NC = 奇数の期間に一致する、擬似利払期間の数。この数値に小数が含まれている場合は、次の整数に上げられます。NC = number of quasi-coupon periods that fit in odd period; if this number contains a fraction, it will be raised to the next whole number.
  • NLi = 奇数利払期間内の i 番目または最後の準利払期間の日数での通常の長さ。NLi = normal length in days of the ith, or last, quasi-coupon period within odd coupon period.

サポートとフィードバックSupport and feedback

Office VBA またはこの説明書に関するご質問やフィードバックがありますか?Have questions or feedback about Office VBA or this documentation? サポートの受け方およびフィードバックをお寄せいただく方法のガイダンスについては、Office VBA のサポートおよびフィードバックを参照してください。Please see Office VBA support and feedback for guidance about the ways you can receive support and provide feedback.