欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用Java巧妙解決Excel公式迭代計算

 更新時間:2023年10月24日 10:21:20   作者:葡萄城技術(shù)團隊  
迭代計算其實是在?Excel?中,一種公式的循環(huán)引用,那么如何利用Java語言巧妙解決Excel公式迭代計算的問題呢,下面小編就來和大家詳細講講吧

什么是迭代計算

迭代計算其實是在 Excel 中,一種公式的循環(huán)引用,對于了解編程概念的同學,很容易會想到另一個詞“遞歸”。

簡單的說,就是一段程序調(diào)用自己,反復執(zhí)行的邏輯。遞歸在編程中,屬于中高級用法,因為遞歸需要一個中斷的條件,對于初級的邏輯,遞歸很容易造成程序無限遞歸,出現(xiàn) Stack Overflow(堆棧溢出)。

在 Excel 里,也是一樣的,迭代計算指的是,公式引用中出現(xiàn)了循環(huán)引用。

舉個例子:

A1 = A1 + 1;

A1 的結(jié)果是多少?如下圖所示,通常 Excel 會通過提示,禁止循環(huán)引用的出現(xiàn)。

但是當小編開啟迭代計算后,Excel 則允許循環(huán)引用。

此時,再看看剛才的公式,結(jié)果為 100。

所以,什么是迭代計算?

在 Excel 中,當出現(xiàn)循環(huán)引用時,反復循環(huán)遞歸的計算,即為迭代計算。迭代次數(shù)及迭代誤差,可以在 Excel 的設(shè)置中配置。默認為 100 次。

迭代計算的使用場景

在很多數(shù)學模型的計算中,沒有特定的公式進行求解,而是需要不停的計算,反復逼近一個期望的結(jié)果。

同時,迭代計算也適用于水利工程,地質(zhì)工程的設(shè)計時的相關(guān)數(shù)據(jù)計算。

Java 中如何使用迭代計算

1. A1 = A1 + 1場景

接下來小編將以葡萄城公司的 Java API組件——GrapeCity Documents for Excel(以下簡稱為GcExcel)為例,為大家介紹如何在Java中實現(xiàn)迭代計算。

以上述提到過的A1 = A1 + 1 場景為例,下面是具體的代碼:

// Create a new workbook
Workbook workbook = new Workbook();

// Enable iterative calculation
workbook.getOptions().getFormulas().setEnableIterativeCalculation(true);
workbook.getOptions().getFormulas().setMaximumIterations(10);
IWorksheet worksheet = workbook.getWorksheets().get(0);
worksheet.getRange("A1").setFormula("=B1 + 1");
worksheet.getRange("B1").setFormula("=A1 + 1");

System.out.println("A1:" + worksheet.getRange("A1").getValue().toString());
System.out.println("B1:" + worksheet.getRange("B1").getValue().toString());
    
// Save to an excel file
workbook.save("IterativeCalculation.xlsx");

運行程序,可以看到實現(xiàn)的效果:

結(jié)果值和使用Excel中使用公式的效果是一樣的,都是100。

2. IRR場景

接下來以 IRR 為例用 Excel 做一次計算。

IRR 的概念是,當 N 年的凈利潤為 0 時,內(nèi)部的收益率。

假設(shè)投資本金為 1 萬,每年收益如下,在 Excel 中,分別用迭代計算和 IRR 公式進行計算。

IRR 是復利計算,假定 E7 和 E8 兩個格子分別是 IRR。那么通過 IRR,在 F8 中可以根據(jù)復利公式進行計算。

其中 E7 為 IRR,IRR 需要使得上述的公式近似為 0。因此可以使用迭代計算來反推 IRR,E7 公式如下:

可以看到,小編一開始給 E7 定了一個初始值 0.3 (30%)。然后判斷 F7 (NPV)的值,凈值會隨著 IRR 變小,逐漸變大,而 - 0.000001,則是每一次計算,對于 IRR 的調(diào)整。假定當 NPV 大于 0 時,IRR 計算停止,只要每一次對 IRR 的調(diào)整足夠小,就可以近似的認為當 NPV 大于 0 的那一次結(jié)果趨近于 0。

經(jīng)過反復計算,其結(jié)果如下:

那么在 Java 中,如何通過迭代計算來計算 IRR 呢?

通過借助GcExcel, 可以很方便的把剛才的公式直接放在代碼里即可進行計算,代碼如下:

public void IRR() {
    // Create a new workbook
    Workbook workbook = new Workbook();

    // Enable iterative calculation
    workbook.getOptions().getFormulas().setEnableIterativeCalculation(true);
    workbook.getOptions().getFormulas().setMaximumIterations(1000000);
    IWorksheet worksheet = workbook.getActiveSheet();
    worksheet.getRange("B1").setValue(-10000);
    worksheet.getRange("B2").setValue(1000);
    worksheet.getRange("B3").setValue(1500);
    worksheet.getRange("B4").setValue(2300);
    worksheet.getRange("B5").setValue(3200);
    worksheet.getRange("B6").setValue(4600);
    worksheet.getRange("B7").setValue(6800);
    worksheet.getRange("E7").setFormula("=IF(E7 = 0,E7+1,IF(F7 < 0,E7-0.000001,E7))");
    worksheet.getRange("F7").setFormula("=B1+B2/(1+E7)+B3/(1+E7)^2+B4/(1+E7)^3+B5/(1+E7)^4+B6/(1+E7)^5+B7/(1+E7)^6");

    System.out.println("E7 IRR:" + worksheet.getRange("E7").getValue().toString());
}

計算結(jié)果:和 Excel 里計算的值基本一致。

到此這篇關(guān)于利用Java巧妙解決Excel公式迭代計算的文章就介紹到這了,更多相關(guān)Java Excel公式迭代計算內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Springboot實現(xiàn)自定義錯誤頁面的方法(錯誤處理機制)

    Springboot實現(xiàn)自定義錯誤頁面的方法(錯誤處理機制)

    這篇文章主要介紹了Springboot實現(xiàn)自定義錯誤頁面的方法(錯誤處理機制),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • springboot 自定義屬性與加載@value示例詳解

    springboot 自定義屬性與加載@value示例詳解

    在SpringBoot框架中,自定義屬性通常通過application.properties文件配置,并使用@Value注解加載,雖然這是一種可行的方法,但存在一種更優(yōu)雅的實現(xiàn)方式,本文給大家介紹springboot 自定義屬性與加載@value的相關(guān)操作,感興趣的朋友一起看看吧
    2024-10-10
  • Java使用System.currentTimeMillis()方法計算程序運行時間的示例代碼

    Java使用System.currentTimeMillis()方法計算程序運行時間的示例代碼

    System.currentTimeMillis() 方法的返回類型為 long ,表示毫秒為單位的當前時間,文中通過示例代碼介紹了計算 String 類型與 StringBuilder 類型拼接字符串的耗時情況,對Java計算程序運行時間相關(guān)知識感興趣的朋友一起看看吧
    2022-03-03
  • 利用stream sorted進行降序排序

    利用stream sorted進行降序排序

    這篇文章主要介紹了利用stream sorted進行降序排序,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • 如何使用Resttemplate和Ribbon調(diào)用Eureka實現(xiàn)負載均衡

    如何使用Resttemplate和Ribbon調(diào)用Eureka實現(xiàn)負載均衡

    這篇文章主要介紹了如何使用Resttemplate和Ribbon調(diào)用Eureka實現(xiàn)負載均衡,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • JAVA 線程通信相關(guān)知識匯總

    JAVA 線程通信相關(guān)知識匯總

    這篇文章主要介紹了JAVA 線程通信相關(guān)知識,文中講解非常細致,代碼幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-06-06
  • 解決在啟動eclipse的tomcat進行訪問時出現(xiàn)404問題的方法

    解決在啟動eclipse的tomcat進行訪問時出現(xiàn)404問題的方法

    這篇文章主要介紹了解決在啟動eclipse的tomcat進行訪問時出現(xiàn)404問題的方法,感興趣的小伙伴們可以參考一下
    2016-04-04
  • Java利用完全二叉樹創(chuàng)建大根堆和小根堆

    Java利用完全二叉樹創(chuàng)建大根堆和小根堆

    大根堆是每個結(jié)點的值不大于他的父親結(jié)點的值;小根堆是每個結(jié)點的值不小于他的父親結(jié)點的值。本文將利用完全二叉樹創(chuàng)建大根堆和小根堆,感興趣的可以了解一下
    2022-08-08
  • intellij idea如何配置網(wǎng)絡(luò)代理

    intellij idea如何配置網(wǎng)絡(luò)代理

    intellij idea所在的這臺電腦本身上不了網(wǎng),要通過代理上網(wǎng),那么intellij idea怎么設(shè)置代理上網(wǎng)呢?今天通過本文給大家分享intellij idea如何配置網(wǎng)絡(luò)代理,感興趣的朋友一起看看吧
    2023-10-10
  • JMX監(jiān)控的具體使用

    JMX監(jiān)控的具體使用

    JMX最常見的場景是監(jiān)控Java程序的基本信息和運行情況,本文主要介紹了JMX監(jiān)控的具體使用,具有一定的參考價值,感興趣的可以了解一下
    2024-02-02

最新評論