C# 积木模块 ABC(一)
来源:网络整理 责任编辑:栏目编辑 发表时间:2013-07-02 02:23 点击:次
第一个C#程序:经典例程Hello World
“Hello World”可以说是学习每一种编程语言的第一个例程了。我们可以在NotePad、Wordpad等任何编辑器中输入以下的C#代码,并保存为helloworld.cs,最后在命令行中执行csc helloworld.cs来运行文件:
// using system
using System;
class Hello
{
static void Main() { // display output on console
Console.WriteLine("Hello,C# World!");
}
}
用OpenFileDialog类浏览或打开文件
同VC++中CfileDialog的 Open 方法相同,C#中的OpenFileDialog类可用于打开一个文件。这个类是从FileDialog派生出来的。用这个类中的 OpenFile方法打开一个文件,然后就可以通过流(steam)来读取这个文件。
请看下面的例程代码,它使用 OpenFileDialog类浏览一个文件:
OpenFileDialog fdlg = new OpenFileDialog();
fdlg.Title = "C# Corner Open File Dialog" ;
fdlg.InitialDirectory = @"c:" ;
fdlg.Filter = "All files (*.*)|*.*|All files (*.*)|*.*" ;
fdlg.FilterIndex = 2 ;
fdlg.RestoreDirectory = true ;
if(fdlg.ShowDialog() == DialogResult.OK)
{
textBox1.Text = fdlg.FileName ;
}
Title一行设置打开对话框的标题,Filter一行为打开的文件类型设置一个过滤器,FileName一行包含了所选中的文件名。
下图就是运行的结果:
从C#中调用COM组件
.NET框架是COM的一个自然发展,两者共享许多核心要素,这包括组件的再利用以及语言的中立性。为了向后兼容,COM Interop可以使用现存的COM组件而不要求对原始组件进行修改。当一个 .NET 框架开发人员想将COM代码合并到一个管理应用程序中时,就可以用COM Interop功能引入相关的COM类型。引入之后,这个COM类型就可以使用了。这属于前期连接。但是有时候你需要对象的后期连接,这在.NET中也能实现,使用名称空间映射就可以通过后期连接来调用COM对象。
这里介绍一个应用程序例程,它将调用Excel,并且通过使用后期连接使它可视。
后期连接将使用Reflectionb的Type类,这个Type类有许多方法可以取得COM对象,就象我们已经使用过的 GetTypeFromProgID("Application"),这个方法从系统注册表中得到COM ID,然后使用STATIC类的成员 Activator.CreateInstance()创建这个COM对象的一个新例示。
要想调用COM对象的方法、函数和属性,就必须使用包含正确设置的Type对象的InvokeMethod()方法。这个方法接受一些参数变量,其中最重要的一个是方法类型的ex属性(get或set)。在例子中我们为Excel.Visible使用了set属性,从而使Excel应用程序可视。
我们将尝试在.NET环境中调用Excel应用程序。这是一个后期连接应用程序,因为如果是前期连接的话你就需要使用COM对象的RCW(RunTime Callable Wraper:运行时间的可调用包)来完成下面的命令行程序tblimp所完成的任务:
ex. c:> tblimp /out:
下载COMinDOTNET.zip,这是一个控制台应用程序。下面是调用excel的代码:
//Variable
Type excel;
object[] parameter= new object[1];
object excelObject;
try
{
//Get the excel object
excel = Type.GetTypeFromProgID("Excel.Application");
//Create instance of excel
excelObject = Activator.CreateInstance(excel);
//Set the parameter whic u want to set
parameter[0] = true;
//Set the Visible property
excel.InvokeMember("Visible", BindingFlags.SetProperty, null, excelObject, parameter);
}
“Hello World”可以说是学习每一种编程语言的第一个例程了。我们可以在NotePad、Wordpad等任何编辑器中输入以下的C#代码,并保存为helloworld.cs,最后在命令行中执行csc helloworld.cs来运行文件:
// using system
using System;
class Hello
{
static void Main() { // display output on console
Console.WriteLine("Hello,C# World!");
}
}
用OpenFileDialog类浏览或打开文件
同VC++中CfileDialog的 Open 方法相同,C#中的OpenFileDialog类可用于打开一个文件。这个类是从FileDialog派生出来的。用这个类中的 OpenFile方法打开一个文件,然后就可以通过流(steam)来读取这个文件。
请看下面的例程代码,它使用 OpenFileDialog类浏览一个文件:
OpenFileDialog fdlg = new OpenFileDialog();
fdlg.Title = "C# Corner Open File Dialog" ;
fdlg.InitialDirectory = @"c:" ;
fdlg.Filter = "All files (*.*)|*.*|All files (*.*)|*.*" ;
fdlg.FilterIndex = 2 ;
fdlg.RestoreDirectory = true ;
if(fdlg.ShowDialog() == DialogResult.OK)
{
textBox1.Text = fdlg.FileName ;
}
Title一行设置打开对话框的标题,Filter一行为打开的文件类型设置一个过滤器,FileName一行包含了所选中的文件名。
下图就是运行的结果:
从C#中调用COM组件
.NET框架是COM的一个自然发展,两者共享许多核心要素,这包括组件的再利用以及语言的中立性。为了向后兼容,COM Interop可以使用现存的COM组件而不要求对原始组件进行修改。当一个 .NET 框架开发人员想将COM代码合并到一个管理应用程序中时,就可以用COM Interop功能引入相关的COM类型。引入之后,这个COM类型就可以使用了。这属于前期连接。但是有时候你需要对象的后期连接,这在.NET中也能实现,使用名称空间映射就可以通过后期连接来调用COM对象。
这里介绍一个应用程序例程,它将调用Excel,并且通过使用后期连接使它可视。
后期连接将使用Reflectionb的Type类,这个Type类有许多方法可以取得COM对象,就象我们已经使用过的 GetTypeFromProgID("Application"),这个方法从系统注册表中得到COM ID,然后使用STATIC类的成员 Activator.CreateInstance()创建这个COM对象的一个新例示。
要想调用COM对象的方法、函数和属性,就必须使用包含正确设置的Type对象的InvokeMethod()方法。这个方法接受一些参数变量,其中最重要的一个是方法类型的ex属性(get或set)。在例子中我们为Excel.Visible使用了set属性,从而使Excel应用程序可视。
我们将尝试在.NET环境中调用Excel应用程序。这是一个后期连接应用程序,因为如果是前期连接的话你就需要使用COM对象的RCW(RunTime Callable Wraper:运行时间的可调用包)来完成下面的命令行程序tblimp所完成的任务:
ex. c:> tblimp /out:
下载COMinDOTNET.zip,这是一个控制台应用程序。下面是调用excel的代码:
//Variable
Type excel;
object[] parameter= new object[1];
object excelObject;
try
{
//Get the excel object
excel = Type.GetTypeFromProgID("Excel.Application");
//Create instance of excel
excelObject = Activator.CreateInstance(excel);
//Set the parameter whic u want to set
parameter[0] = true;
//Set the Visible property
excel.InvokeMember("Visible", BindingFlags.SetProperty, null, excelObject, parameter);
}
相关新闻>>
最新推荐更多>>>
- 发表评论
-
- 最新评论 更多>>