表达式计算器
一个表达式计算器,用C#写的,利用了VB编译器的强劲性能,可以计算任何合法的VB表达式,可以有一个自变量(x),也可以不要自变量。
计算表达式的代码用的是“银河”的代码(VB版):
http://www.cnblogs.com/skyivben/archive/2005/10/31/265861.html

  1 // Calc.cs - 表达式计算器
// Calc.cs - 表达式计算器
2 // 编译方法: csc /t:winexe Calc.cs VBExpression.cs
// 编译方法: csc /t:winexe Calc.cs VBExpression.cs
3
4 using System;
using System;
5 using System.Windows.Forms;
using System.Windows.Forms;
6 using Skyiv.Util;
using Skyiv.Util;
7
8 namespace Skyiv
namespace Skyiv
9 {
{
10 class Calc : Form
  class Calc : Form
11 {
  {
12 TextBox tbxA1, tbxA2, tbxA3;
    TextBox tbxA1, tbxA2, tbxA3;
13
14 Calc()
    Calc()
15 {
    {
16 Text              = "表达式计算器";
      Text              = "表达式计算器";
17 StartPosition     = FormStartPosition.CenterScreen;
      StartPosition     = FormStartPosition.CenterScreen;
18 Width             = 400;
      Width             = 400;
19 Height            = 200;
      Height            = 200;
20
21 Label lblA1       = new Label();
      Label lblA1       = new Label();
22 lblA1.Text        = "表达式(&E)";
      lblA1.Text        = "表达式(&E)";
23 lblA1.Parent      = this;
      lblA1.Parent      = this;
24 lblA1.Top         = 23;
      lblA1.Top         = 23;
25 lblA1.Left        = 10;
      lblA1.Left        = 10;
26 lblA1.AutoSize    = true;
      lblA1.AutoSize    = true;
27
28 tbxA1             = new TextBox();
      tbxA1             = new TextBox();
29 tbxA1.Parent      = this;
      tbxA1.Parent      = this;
30 tbxA1.Top         = 20;
      tbxA1.Top         = 20;
31 tbxA1.Left        = 80;
      tbxA1.Left        = 80;
32 tbxA1.Width       = 300;
      tbxA1.Width       = 300;
33 tbxA1.BorderStyle = BorderStyle.FixedSingle;
      tbxA1.BorderStyle = BorderStyle.FixedSingle;
34
35 Label lblA2       = new Label();
      Label lblA2       = new Label();
36 lblA2.Text        = "自变量(&X)";
      lblA2.Text        = "自变量(&X)";
37 lblA2.Parent      = this;
      lblA2.Parent      = this;
38 lblA2.Top         = 48;
      lblA2.Top         = 48;
39 lblA2.Left        = 10;
      lblA2.Left        = 10;
40 lblA2.AutoSize    = true;
      lblA2.AutoSize    = true;
41
42 tbxA2             = new TextBox();
      tbxA2             = new TextBox();
43 tbxA2.Parent      = this;
      tbxA2.Parent      = this;
44 tbxA2.Top         = 45;
      tbxA2.Top         = 45;
45 tbxA2.Left        = 80;
      tbxA2.Left        = 80;
46 tbxA2.Width       = 300;
      tbxA2.Width       = 300;
47 tbxA2.BorderStyle = BorderStyle.FixedSingle;
      tbxA2.BorderStyle = BorderStyle.FixedSingle;
48
49 Button btnA3      = new Button();
      Button btnA3      = new Button();
50 btnA3.Text        = "计算(&C)";
      btnA3.Text        = "计算(&C)";
51 btnA3.Parent      = this;
      btnA3.Parent      = this;
52 btnA3.Top         = 70;
      btnA3.Top         = 70;
53 btnA3.Left        = 10;
      btnA3.Left        = 10;
54 btnA3.Width       = 62;
      btnA3.Width       = 62;
55 btnA3.Click      += new EventHandler(Calc_Clicked);
      btnA3.Click      += new EventHandler(Calc_Clicked);
56
57 tbxA3             = new TextBox();
      tbxA3             = new TextBox();
58 tbxA3.Parent      = this;
      tbxA3.Parent      = this;
59 tbxA3.Top         = 70;
      tbxA3.Top         = 70;
60 tbxA3.Left        = 80;
      tbxA3.Left        = 80;
61 tbxA3.Width       = 300;
      tbxA3.Width       = 300;
62 tbxA3.BorderStyle = BorderStyle.FixedSingle;
      tbxA3.BorderStyle = BorderStyle.FixedSingle;
63 tbxA3.ReadOnly    = true;
      tbxA3.ReadOnly    = true;
64
65
66 TextBox tbxA4     = new TextBox();
      TextBox tbxA4     = new TextBox();
67 tbxA4.Text        = @"
      tbxA4.Text        = @"
68 表达式使用 Visual Baisc 语法,可带一个的自变量(x)
表达式使用 Visual Baisc 语法,可带一个的自变量(x)
69 可使用 pi、e 等常量,sin、cos、tan、log、sqrt 等函数
可使用 pi、e 等常量,sin、cos、tan、log、sqrt 等函数
70 例子:x * cos(x * pi / sqrt(25 * 6^4)) + log(E^10)";
例子:x * cos(x * pi / sqrt(25 * 6^4)) + log(E^10)";
71 tbxA4.Parent      = this;
      tbxA4.Parent      = this;
72 tbxA4.Top         = 95;
      tbxA4.Top         = 95;
73 tbxA4.Left        = 10;
      tbxA4.Left        = 10;
74 tbxA4.Width       = 370;
      tbxA4.Width       = 370;
75 tbxA4.Height      = 65;
      tbxA4.Height      = 65;
76 tbxA4.BorderStyle = BorderStyle.None;
      tbxA4.BorderStyle = BorderStyle.None;
77 tbxA4.Multiline   = true;
      tbxA4.Multiline   = true;
78 tbxA4.ReadOnly    = true;
      tbxA4.ReadOnly    = true;
79 }
    }
80
81 void Calc_Clicked(object sender, EventArgs ea)
    void Calc_Clicked(object sender, EventArgs ea)
82 {
    {
83 (sender as Control).Enabled = false;
      (sender as Control).Enabled = false;
84 try
      try
85 {
      {
86 double x = 0;
        double x = 0;
87 if (tbxA2.Text.Trim().Length != 0)
        if (tbxA2.Text.Trim().Length != 0)
88 {
        {
89 try
          try
90 {
          {
91 x = double.Parse(tbxA2.Text);
            x = double.Parse(tbxA2.Text);
92 }
          }
93 catch
          catch
94 {
          {
95 try
            try
96 {
            {
97 x = (new Expression(tbxA2.Text)).Compute(0);
              x = (new Expression(tbxA2.Text)).Compute(0);
98 }
            }
99 catch (Exception ex)
            catch (Exception ex)
100 {
            {
101 MessageBox.Show(ex.Message, "自变量出错");
              MessageBox.Show(ex.Message, "自变量出错");
102 }
            }
103 }
          }
104 }
        }
105 tbxA3.Text = (new Expression(tbxA1.Text)).Compute(x).ToString();
        tbxA3.Text = (new Expression(tbxA1.Text)).Compute(x).ToString();
106 }
      }
107 catch (Exception ex)
      catch (Exception ex)
108 {
      {
109 MessageBox.Show(ex.Message, "表达式出错");
        MessageBox.Show(ex.Message, "表达式出错");
110 }
      }
111 finally
      finally
112 {
      {
113 (sender as Control).Enabled = true;
        (sender as Control).Enabled = true;
114 }
      }
115 }
    }
116
117 [STAThread]
    [STAThread]
118 static void Main(string [] args)
    static void Main(string [] args)
119 {
    {
120 Application.Run(new Calc());
      Application.Run(new Calc());
121 }
    }
122 }
  }
123 }
}
124
 // Calc.cs - 表达式计算器
// Calc.cs - 表达式计算器2
 // 编译方法: csc /t:winexe Calc.cs VBExpression.cs
// 编译方法: csc /t:winexe Calc.cs VBExpression.cs3

4
 using System;
using System;5
 using System.Windows.Forms;
using System.Windows.Forms;6
 using Skyiv.Util;
using Skyiv.Util;7

8
 namespace Skyiv
namespace Skyiv9
 {
{10
 class Calc : Form
  class Calc : Form11
 {
  {12
 TextBox tbxA1, tbxA2, tbxA3;
    TextBox tbxA1, tbxA2, tbxA3;13

14
 Calc()
    Calc()15
 {
    {16
 Text              = "表达式计算器";
      Text              = "表达式计算器";17
 StartPosition     = FormStartPosition.CenterScreen;
      StartPosition     = FormStartPosition.CenterScreen;18
 Width             = 400;
      Width             = 400;19
 Height            = 200;
      Height            = 200;20

21
 Label lblA1       = new Label();
      Label lblA1       = new Label();22
 lblA1.Text        = "表达式(&E)";
      lblA1.Text        = "表达式(&E)";23
 lblA1.Parent      = this;
      lblA1.Parent      = this;24
 lblA1.Top         = 23;
      lblA1.Top         = 23;25
 lblA1.Left        = 10;
      lblA1.Left        = 10;26
 lblA1.AutoSize    = true;
      lblA1.AutoSize    = true;27

28
 tbxA1             = new TextBox();
      tbxA1             = new TextBox();29
 tbxA1.Parent      = this;
      tbxA1.Parent      = this;30
 tbxA1.Top         = 20;
      tbxA1.Top         = 20;31
 tbxA1.Left        = 80;
      tbxA1.Left        = 80;32
 tbxA1.Width       = 300;
      tbxA1.Width       = 300;33
 tbxA1.BorderStyle = BorderStyle.FixedSingle;
      tbxA1.BorderStyle = BorderStyle.FixedSingle;34

35
 Label lblA2       = new Label();
      Label lblA2       = new Label();36
 lblA2.Text        = "自变量(&X)";
      lblA2.Text        = "自变量(&X)";37
 lblA2.Parent      = this;
      lblA2.Parent      = this;38
 lblA2.Top         = 48;
      lblA2.Top         = 48;39
 lblA2.Left        = 10;
      lblA2.Left        = 10;40
 lblA2.AutoSize    = true;
      lblA2.AutoSize    = true;41

42
 tbxA2             = new TextBox();
      tbxA2             = new TextBox();43
 tbxA2.Parent      = this;
      tbxA2.Parent      = this;44
 tbxA2.Top         = 45;
      tbxA2.Top         = 45;45
 tbxA2.Left        = 80;
      tbxA2.Left        = 80;46
 tbxA2.Width       = 300;
      tbxA2.Width       = 300;47
 tbxA2.BorderStyle = BorderStyle.FixedSingle;
      tbxA2.BorderStyle = BorderStyle.FixedSingle;48

49
 Button btnA3      = new Button();
      Button btnA3      = new Button();50
 btnA3.Text        = "计算(&C)";
      btnA3.Text        = "计算(&C)";51
 btnA3.Parent      = this;
      btnA3.Parent      = this;52
 btnA3.Top         = 70;
      btnA3.Top         = 70;53
 btnA3.Left        = 10;
      btnA3.Left        = 10;54
 btnA3.Width       = 62;
      btnA3.Width       = 62;55
 btnA3.Click      += new EventHandler(Calc_Clicked);
      btnA3.Click      += new EventHandler(Calc_Clicked);56

57
 tbxA3             = new TextBox();
      tbxA3             = new TextBox();58
 tbxA3.Parent      = this;
      tbxA3.Parent      = this;59
 tbxA3.Top         = 70;
      tbxA3.Top         = 70;60
 tbxA3.Left        = 80;
      tbxA3.Left        = 80;61
 tbxA3.Width       = 300;
      tbxA3.Width       = 300;62
 tbxA3.BorderStyle = BorderStyle.FixedSingle;
      tbxA3.BorderStyle = BorderStyle.FixedSingle;63
 tbxA3.ReadOnly    = true;
      tbxA3.ReadOnly    = true;64

65

66
 TextBox tbxA4     = new TextBox();
      TextBox tbxA4     = new TextBox();67
 tbxA4.Text        = @"
      tbxA4.Text        = @"68
 表达式使用 Visual Baisc 语法,可带一个的自变量(x)
表达式使用 Visual Baisc 语法,可带一个的自变量(x)69
 可使用 pi、e 等常量,sin、cos、tan、log、sqrt 等函数
可使用 pi、e 等常量,sin、cos、tan、log、sqrt 等函数70
 例子:x * cos(x * pi / sqrt(25 * 6^4)) + log(E^10)";
例子:x * cos(x * pi / sqrt(25 * 6^4)) + log(E^10)";71
 tbxA4.Parent      = this;
      tbxA4.Parent      = this;72
 tbxA4.Top         = 95;
      tbxA4.Top         = 95;73
 tbxA4.Left        = 10;
      tbxA4.Left        = 10;74
 tbxA4.Width       = 370;
      tbxA4.Width       = 370;75
 tbxA4.Height      = 65;
      tbxA4.Height      = 65;76
 tbxA4.BorderStyle = BorderStyle.None;
      tbxA4.BorderStyle = BorderStyle.None;77
 tbxA4.Multiline   = true;
      tbxA4.Multiline   = true;78
 tbxA4.ReadOnly    = true;
      tbxA4.ReadOnly    = true;79
 }
    }80

81
 void Calc_Clicked(object sender, EventArgs ea)
    void Calc_Clicked(object sender, EventArgs ea)82
 {
    {83
 (sender as Control).Enabled = false;
      (sender as Control).Enabled = false;84
 try
      try85
 {
      {86
 double x = 0;
        double x = 0;87
 if (tbxA2.Text.Trim().Length != 0)
        if (tbxA2.Text.Trim().Length != 0)88
 {
        {89
 try
          try90
 {
          {91
 x = double.Parse(tbxA2.Text);
            x = double.Parse(tbxA2.Text);92
 }
          }93
 catch
          catch94
 {
          {95
 try
            try96
 {
            {97
 x = (new Expression(tbxA2.Text)).Compute(0);
              x = (new Expression(tbxA2.Text)).Compute(0);98
 }
            }99
 catch (Exception ex)
            catch (Exception ex)100
 {
            {101
 MessageBox.Show(ex.Message, "自变量出错");
              MessageBox.Show(ex.Message, "自变量出错");102
 }
            }103
 }
          }104
 }
        }105
 tbxA3.Text = (new Expression(tbxA1.Text)).Compute(x).ToString();
        tbxA3.Text = (new Expression(tbxA1.Text)).Compute(x).ToString();106
 }
      }107
 catch (Exception ex)
      catch (Exception ex)108
 {
      {109
 MessageBox.Show(ex.Message, "表达式出错");
        MessageBox.Show(ex.Message, "表达式出错");110
 }
      }111
 finally
      finally112
 {
      {113
 (sender as Control).Enabled = true;
        (sender as Control).Enabled = true;114
 }
      }115
 }
    }116

117
 [STAThread]
    [STAThread]118
 static void Main(string [] args)
    static void Main(string [] args)119
 {
    {120
 Application.Run(new Calc());
      Application.Run(new Calc());121
 }
    }122
 }
  }123
 }
}124

计算表达式的代码用的是“银河”的代码(VB版):
http://www.cnblogs.com/skyivben/archive/2005/10/31/265861.html
 1 // VBExpression.cs - 动态生成数学表达式并计算其值
// VBExpression.cs - 动态生成数学表达式并计算其值
2 // 表达式使用 Visual Baisc 语法,可带一个的自变量(x)
// 表达式使用 Visual Baisc 语法,可带一个的自变量(x)
3 // 可使用 pi、e 等常量,sin、cos、tan、log、sqrt 等函数
// 可使用 pi、e 等常量,sin、cos、tan、log、sqrt 等函数
4 // 例子:e + sqrt(log(pi ^ e) * x) + sin(x * pi / 180)
// 例子:e + sqrt(log(pi ^ e) * x) + sin(x * pi / 180)
5
6 using System;
using System;
7 using System.CodeDom.Compiler;
using System.CodeDom.Compiler;
8 using Microsoft.VisualBasic;
using Microsoft.VisualBasic;
9 using System.Reflection;
using System.Reflection;
10 using System.Text;
using System.Text;
11 using System.Globalization;
using System.Globalization;
12
13 namespace Skyiv.Util
namespace Skyiv.Util
14 {
{
15 sealed class Expression
  sealed class Expression
16 {
  {
17 object instance;
    object instance;
18 MethodInfo method;
    MethodInfo method;
19
20 public Expression(string expression)
    public Expression(string expression)
21 {
    {
22 if (expression.ToUpper(CultureInfo.InvariantCulture).IndexOf("RETURN") < 0) expression = "Return " + expression;
      if (expression.ToUpper(CultureInfo.InvariantCulture).IndexOf("RETURN") < 0) expression = "Return " + expression;
23 string className = "Expression";
      string className = "Expression";
24 string methodName = "Compute";
      string methodName = "Compute";
25 CompilerParameters p = new CompilerParameters();
      CompilerParameters p = new CompilerParameters();
26 p.GenerateInMemory = true;
      p.GenerateInMemory = true;
27 CompilerResults cr = new VBCodeProvider().CompileAssemblyFromSource
      CompilerResults cr = new VBCodeProvider().CompileAssemblyFromSource
28 (
      (
29 p,
        p,
30 string.Format
        string.Format
31 (
        (
32 @"Option Explicit Off
          @"Option Explicit Off
33 Option Strict Off
          Option Strict Off
34 Imports System, System.Math, Microsoft.VisualBasic
          Imports System, System.Math, Microsoft.VisualBasic
35 NotInheritable Class {0}
          NotInheritable Class {0}
36 Public Function {1}(x As Double) As Double
          Public Function {1}(x As Double) As Double
37 {2}
          {2}
38 End Function
          End Function
39 End Class",
          End Class",
40 className, methodName, expression
          className, methodName, expression
41 )
        )
42 );
      );
43 if(cr.Errors.Count > 0)
      if(cr.Errors.Count > 0)
44 {
      {
45 string msg = "Expression(\"" + expression + "\"): \n";
        string msg = "Expression(\"" + expression + "\"): \n";
46 foreach (CompilerError err in cr.Errors) msg += err.ToString() + "\n";
        foreach (CompilerError err in cr.Errors) msg += err.ToString() + "\n";
47 throw new Exception(msg);
        throw new Exception(msg);
48 }
      }
49 instance = cr.CompiledAssembly.CreateInstance(className);
      instance = cr.CompiledAssembly.CreateInstance(className);
50 method = instance.GetType().GetMethod(methodName);
      method = instance.GetType().GetMethod(methodName);
51 }
    }
52
53 public double Compute(double x)
    public double Compute(double x)
54 {
    {
55 return (double)method.Invoke(instance, new object [] { x });
      return (double)method.Invoke(instance, new object [] { x });
56 }
    }
57 }
  }
58 }
}
59
 
 // VBExpression.cs - 动态生成数学表达式并计算其值
// VBExpression.cs - 动态生成数学表达式并计算其值2
 // 表达式使用 Visual Baisc 语法,可带一个的自变量(x)
// 表达式使用 Visual Baisc 语法,可带一个的自变量(x)3
 // 可使用 pi、e 等常量,sin、cos、tan、log、sqrt 等函数
// 可使用 pi、e 等常量,sin、cos、tan、log、sqrt 等函数4
 // 例子:e + sqrt(log(pi ^ e) * x) + sin(x * pi / 180)
// 例子:e + sqrt(log(pi ^ e) * x) + sin(x * pi / 180)5

6
 using System;
using System;7
 using System.CodeDom.Compiler;
using System.CodeDom.Compiler;8
 using Microsoft.VisualBasic;
using Microsoft.VisualBasic;9
 using System.Reflection;
using System.Reflection;10
 using System.Text;
using System.Text;11
 using System.Globalization;
using System.Globalization;12

13
 namespace Skyiv.Util
namespace Skyiv.Util14
 {
{15
 sealed class Expression
  sealed class Expression16
 {
  {17
 object instance;
    object instance;18
 MethodInfo method;
    MethodInfo method;19

20
 public Expression(string expression)
    public Expression(string expression)21
 {
    {22
 if (expression.ToUpper(CultureInfo.InvariantCulture).IndexOf("RETURN") < 0) expression = "Return " + expression;
      if (expression.ToUpper(CultureInfo.InvariantCulture).IndexOf("RETURN") < 0) expression = "Return " + expression;23
 string className = "Expression";
      string className = "Expression";24
 string methodName = "Compute";
      string methodName = "Compute";25
 CompilerParameters p = new CompilerParameters();
      CompilerParameters p = new CompilerParameters();26
 p.GenerateInMemory = true;
      p.GenerateInMemory = true;27
 CompilerResults cr = new VBCodeProvider().CompileAssemblyFromSource
      CompilerResults cr = new VBCodeProvider().CompileAssemblyFromSource28
 (
      (29
 p,
        p,30
 string.Format
        string.Format31
 (
        (32
 @"Option Explicit Off
          @"Option Explicit Off33
 Option Strict Off
          Option Strict Off34
 Imports System, System.Math, Microsoft.VisualBasic
          Imports System, System.Math, Microsoft.VisualBasic35
 NotInheritable Class {0}
          NotInheritable Class {0}36
 Public Function {1}(x As Double) As Double
          Public Function {1}(x As Double) As Double37
 {2}
          {2}38
 End Function
          End Function39
 End Class",
          End Class",40
 className, methodName, expression
          className, methodName, expression41
 )
        )42
 );
      );43
 if(cr.Errors.Count > 0)
      if(cr.Errors.Count > 0)44
 {
      {45
 string msg = "Expression(\"" + expression + "\"): \n";
        string msg = "Expression(\"" + expression + "\"): \n";46
 foreach (CompilerError err in cr.Errors) msg += err.ToString() + "\n";
        foreach (CompilerError err in cr.Errors) msg += err.ToString() + "\n";47
 throw new Exception(msg);
        throw new Exception(msg);48
 }
      }49
 instance = cr.CompiledAssembly.CreateInstance(className);
      instance = cr.CompiledAssembly.CreateInstance(className);50
 method = instance.GetType().GetMethod(methodName);
      method = instance.GetType().GetMethod(methodName);51
 }
    }52

53
 public double Compute(double x)
    public double Compute(double x)54
 {
    {55
 return (double)method.Invoke(instance, new object [] { x });
      return (double)method.Invoke(instance, new object [] { x });56
 }
    }57
 }
  }58
 }
}59

 
                     
                    
                 
                    
                 
 
        

 
   
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号