計算字元串得出結果

来源:https://www.cnblogs.com/mlfg/archive/2019/02/21/10411603.html
-Advertisement-
Play Games

需求: 在C#中對一個字元串進行計算得出結果。 例如:“1+2+66+33” 字元串中的數字可以變化,累加(這裡偷懶了限定成累加)的次數可以變化。 思路/解決方案: 1. 用JavaScript中的Eval把字元串轉成對象進行計算 用Com控制項計算方法,引入MSScriptControl.Scrip ...


需求:

在C#中對一個字元串進行計算得出結果。

例如:“1+2+66+33”

字元串中的數字可以變化,累加(這裡偷懶了限定成累加)的次數可以變化。

思路/解決方案:

1. 用JavaScript中的Eval把字元串轉成對象進行計算

用Com控制項計算方法,引入MSScriptControl.ScriptControlClass

2.用DataTable().Compute計算方法

3.把字元串表達式作為一個sql發到資料庫計算後結果再回傳到程式

4.分解字元串用 lambda表達式樹動態創建一個(累加)表達式

 

說明:

我做了一個隨機數,然後將每次隨機出來的數字拼接成一個字元串展示出來。

再來解析這個字元串得出計算結果。

需要註意表達式樹的方式,你的參數列表paramslist必須是  object[] 這個類型,我之前用的int[] 也可以編譯但是在運行的時候會報錯,你的paramenterArray應當就是構成binaryexpression的那些ParameterExpression。

如果你的業務裡面要用到更加複雜運算,你需要親自來嘗試。

歡迎吐槽。

 

代碼:

using System;
using System.Collections.Generic;
using System.Text;
using System.Linq.Expressions;
using System.Reflection;

namespace guess
{
    class Program
    {
        static void Main(string[] args)
        {
            try
            {
                Console.WriteLine(SetRandomVariable(GetTemplate()));
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.Message);
            }        

#if DEBUG
            Console.Read();
#endif


        }

        private static string GetTemplate()
        {

            StringBuilder stb = new StringBuilder();
            stb.AppendLine("Bangladesh - OneERP {0}hr");
            stb.AppendLine("CN - OneERP {1}hr");
            stb.AppendLine("Global - OneERP {2}hr");
            stb.AppendLine("FE - OneERP {3}hr");
            stb.AppendLine("UK - OneERP {4}hr");
            stb.AppendLine("Turkey - OneERP {5}hr");
            stb.AppendLine("Vietnam – OneERP {6}hr");
            stb.AppendLine("Singapore - OneERP {7}hr");
            stb.AppendLine("CN - HZ {8}hr");
            stb.AppendLine("Romania - OneERP {9}hr");
            stb.AppendLine("Thailand - OneERP {10}hr");
            stb.AppendLine("ZheJiang - OneERP {11}hr");
            stb.AppendLine("Global - OneERP SSO {12}hr");

            return stb.ToString();

        }

        private static string SetRandomVariable(string getTemplate)
        {

            int count = getTemplate.Split('\n').Length - 1;

            Random randomVariable = new Random(DateTime.Now.Millisecond);
            int max = 40;
          
            StringBuilder formula = new StringBuilder();
            object[] paramslist = new object[count];
            for (int i = 0; i < paramslist.Length; i++)
            {
                if (i == paramslist.Length - 1)
                {
                    paramslist[i] = max;
                    formula.Append(max);
                }
                else
                {
                    paramslist[i] = available(ref max, ref formula);
                }

            }

            //Com控制項計算方法 需要目標平臺X86 D找到引用的dll——屬性——嵌入互操作類型——false
            MSScriptControl.ScriptControl sc = new MSScriptControl.ScriptControlClass();
            sc.Language = "JavaScript";
            Console.WriteLine("{0}={1}", formula.ToString(), sc.Eval(formula.ToString()).ToString());


            //DataTable().Compute計算方法
            Console.WriteLine("{0}={1}", formula.ToString(), new System.Data.DataTable().Compute(formula.ToString(), "").ToString());

            //另外有一種思路,把表達式作為一個sql發到資料庫計算後結果再回傳到程式。

            //lambda表達式樹動態創建一個累加的表達式 需要.net FrameWork 4.5
            BinaryExpression binaryexpression = addExpression(count,null);
            Console.WriteLine(binaryexpression);
            LambdaExpression lambdaExpr = Expression.Lambda(binaryexpression, paramenterArray);
            Delegate de = lambdaExpr.Compile();
           // MethodInfo method = de.Method;
            Console.WriteLine(de.DynamicInvoke(paramslist));
            return string.Format(getTemplate, paramslist);
           
        }

        private static int available(ref int max, ref StringBuilder formula)
        {


            int temp = 0;
            if (max > 0)
            {
                Random randomVariable = new Random();
                if (max == 1)
                {
                    temp = randomVariable.Next(0, max + 1);
                }
                else
                {
                    temp = randomVariable.Next(0, max);
                }
                max = max - temp;
            }
            formula.AppendFormat("{0}+", temp);
            return temp;

        }
       static List<ParameterExpression>  paramenterArray=new List<ParameterExpression>() ;

        /// <summary>
        /// 
        /// </summary>
        /// <param name="lenght">累加次數</param>
        /// <param name="resultLeft">預設累加表達式</param>
        /// <returns></returns>
        private static BinaryExpression addExpression(int lenght, BinaryExpression resultLeft)
        {

            try
            {
                ParameterExpression left, right;
                left = Expression.Parameter(typeof(int), string.Format("left{0}", lenght) );
                right = Expression.Parameter(typeof(int), string.Format("right{0}", (lenght - 1)) );
                BinaryExpression result = Expression.Add(left, right);

                if (lenght > 2)
                {
                    paramenterArray.Add(left);
                    paramenterArray.Add(right);
                    if (resultLeft != null)
                        result = Expression.Add(resultLeft, addExpression(lenght - 2, result));
                    else
                        result = addExpression(lenght - 2, result);

                }
                if (lenght == 2)
                {
                    paramenterArray.Add(left);
                    paramenterArray.Add(right);
                    if (resultLeft != null)
                        result = Expression.Add(resultLeft, result);
                    else
                    {
                        //ignore;
                    }
                }
                if (lenght == 1)
                {
                    if (resultLeft != null)
                    {
                        ParameterExpression rExpression = Expression.Parameter(typeof(int), string.Format("right{0}", lenght ));
                        paramenterArray.Add(rExpression);
                        result = Expression.Add(resultLeft, rExpression);
                    }
                    else
                    {

                        throw (new Exception("當lenght等於1時,resultLeft參數不能為空"));
                    }
                }
                return result;
            }
            catch ( Exception ex)
            {
#if DEBUG
                Console.WriteLine(ex.StackTrace.ToString());
#endif
                throw (ex);
            }
        }
    }
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 介面類型1.介面類型具體描述了一系列方法的集合,實現這些方法的具體類型是這個介面類型的實例2.一個類型如果擁有一個介面需要的所有方法,那麼這個類型就實現了這個介面 ...
  • ASP.NET core 的Filter是系統中經常用到的,本文詳細分享一下各種Filter定義、執行的內部機制以及執行順序。 一、 概述 ASP.NET Core MVC 中有好幾種常用的篩選器,例如Authorization filters 、Resource filters、Action fi ...
  • 在窗體的InitializeComponent();方法後面添加下麵的代碼。 MdiClient MC = new MdiClient(); MC.Name = "MdiClientForm"; MC.Dock = DockStyle.Fill; MC.BackgroundImageLayout = ...
  • 最近在修改自動化小工具,用多線程來解決後臺拷貝導致WinForm界面卡死的情況,但是遇到過錯:線程間操作無效: 從不是創建控制項“dataGridView”的線程訪問它。 這是因為在多線程程式中,新創建的線程不能訪問UI線程創建的視窗控制項,如果需要訪問視窗中的控制項,有2種解決方法: 1. 在Form_ ...
  • 一.查詢類型 此功能是EF Core 2.1中的新功能。 EF Core除了實體類型之外,EF Core模型還可以包含查詢類型,這些查詢類型是針對“未映射到實體類型”的數據獲取。比如視圖,或只讀數據表。 1.1 下麵介紹下,查詢類型與實體類型共同與不同點: (1) 可以在OnModelCreatin ...
  • 有些場景下,我們需要列舉出Enum中的所有項,比如 Enum轉到下拉列表給用戶選擇,這時我們就需要列出所有項出來了。 ...
  • 現在的項目開發基本上都用到了上傳文件功能,或圖片,或文檔,或視頻。我們常用的常規上傳已經能夠滿足當前要求了, 然而有時會出現如下問題: 我們這裡只講分片上傳,至於斷網續傳和秒傳已經寫好demo,下載路徑放在文末,有興趣的可以下載下來自己玩玩。 分片上傳demo下載地址:https://pan.bai ...
  • 今天給大家推薦一個簡單的獲取手機驗證碼註冊+獲取隨機4位數 測試框架:.net4.7以上 1.榛子雲註冊:http://smsow.zhenzikj.com/,送一條測試簡訊,最低充10元即刻使用 2.註冊完我們在平臺下載一個SDK這是平臺給我們弄好的介面我們只需要下載完就能直接引用了 3.下載好了 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...