-
c语言入门之用程序实现文件的关联
文件关联在程序设计中有着重要的作用,它的目的是要实现某种扩展名的文件由相应的应用程序来打开,有许多的软件,特别试那些媒体播放软件,大都实现了文件的关联,可以想象,一个与文件相关的软件连文件关联就没有做到,它还如何混下去。另外,由于一般应用程序都有自己特定扩展名的数据文件,这也要求软件编制者应在程序中实现自动关联而不能由用户手工去实现。那如何实现文件的关联呢?实现文件关联的核心是对注册表的操作, 所有的文件关联都在HKEY—CLASSES— ROOT 下面, 要实现文件关联必须在HKEY—CLASSES—ROOT 中增加两个键值,一是和文件扩展名对应的类型说明,二是对这种类型文件的操作所需要执行的应用程序。下面范例可以说明如何实现文件的关联,本例的功能是将用户指定扩展名的文件与用户指定的应用程序相关联,双击此种类型的文件时就可以由相应的应用程序来打开。该范例程序是用Borland C++ Builder实现的,部分代码如下:
进行文件的关联:
void __fastcall TForm1::btnAssoClick(TObject *Sender)
{
TRegistry *Reg = new TRegistry;
Reg->RootKey=HKEY_CLASSES_ROOT;
try
{
Reg->OpenKey(extDoWith(edtExt->Text),true);
Reg->WriteString("",appDoWith(edtAppPath->Text));
Reg->CloseKey();
Reg->OpenKey(appDoWith(edtAppPath->Text)+"\\shell\\open\\command",true);
Reg->WriteString("",edtAppPath->Text);
Reg->CloseKey();
}
__finally
{
delete Reg;
}
}
以上代码实现了文件的关联,它用到了C++Builder提供Tregistry组件,它提供了许多用于操作注册表的方法,如:OpenKey打开注册表的某个键,WriteString往注册表了写值等,这就避免了去使用比较麻烦的RegCreateKey、RegSetValue等Win32API来完成同样的功能。 而extDoWith(),appDoWith()分别为自定义的函数它们的功能是设置关联文件的扩展名和取得应用程序的文件名,代码如下:
extDoWith()函数:
AnsiString __fastcall TForm1::extDoWith(AnsiString str)
{
//TODO: Add your source code here
//在扩展名前加上.符号
if (str.SubString(0,1)!=".")
{
str="."+str;
}
return str;
}
appDoWith()函数:
AnsiString __fastcall TForm1::appDoWith(AnsiString appPath)
{
//TODO: Add your source code here
//取得应用程序的文件名,不带扩展名
int length=appPath.Length();
int index=appPath.LastDelimiter("\\");
appPath=appPath.SubString(index+1,length-index+1);
index=appPath.LastDelimiter(".");
appPath=appPath.SubString(0,index-1);
return appPath;
}
这样就实现了文件类型与应用程序的关联,如果您对本程序感兴趣的话,可以到http://www.zccfamily.com/zqget/ 网址下载该程序的工程文件。如果你有与我交流的想法,我的联系方式:email:zqget@msn.com
栏目列表
最新更新
C#基于接口设计三层架构Unity篇
C#线程 入门
C#读取静态类常量属性和值
C# 插件式编程
C# 委托与事件有啥区别?
C#队列学习笔记:队列(Queue)和堆栈(Stack
linq 多表分组左连接查询查询统计
C#队列学习笔记:MSMQ入门一
C# 基础知识系列- 1 数据类型
二、C#入门—基础语法
C# 在Word中添加Latex 数学公式和符号
inncheck命令 – 检查语法
基于UDP的服务器端和客户端
再谈UDP和TCP
在socket编程中使用域名
网络数据传输时的大小端问题
socket编程实现文件传输功能
如何优雅地断开TCP连接?
图解TCP四次握手断开连接
详细分析TCP数据的传输过程
SqlServer 利用游标批量更新数据
BOS只读状态修改
SQL Server等待事件—PAGEIOLATCH_EX
数据库多行转换为单一列
获取数据表最后最后访问,修改,更新,
计算经历的时间
SQL查询结果自定义排序
修改数据库默认位置
日期简单加或减
从日期获取年,月或日