文件关联设置

2011-02-07 14:25:36|  分类: VB.net2008或2010 |  标签:文件关联  |举报|字号 订阅

 
 

原理:以后缀名为.txt为例

方式一:

1、在注册表HKEY_CLASSES_ROOT键下创建一个子键,子键名为.txt然后设置其默认值为Name(Name表示你自己取的名称)

2、再在注册表HKEY_CLASSES_ROOT键下创建一个子键,子键名为Name\Shell\Open\command然后设置command的默认值为关联程序路径即可。

方式二:

在注册表HKEY_CLASSES_ROOT键下创建一个子键,子键名为.txt\Shell\Open\command然后设置command的默认值为关联程序路径即可。

方式二比较简单,但方式一比较常见,这里以方式一的原理为例。以下为示例代码:(调用时直接使用File_Associate(后缀名,关联程序路径)即可)

源代码:

Public Function File_Associate(ByVal Extion As String, ByVal FilePath As String) As Boolean '关联文件,Extion格式为“.txt”,FilePath为关联的程序路径

FilePath = Trim(FilePath)

Extion = Trim(Extion)

If FilePath.Length > 4 And Extion.Length > 2 Then

If Mid(FilePath, FilePath.Length - 3, 4).ToLower = ".exe" And Extion.StartsWith(".") Then

If My.Computer.FileSystem.FileExists(FilePath) And InStr(2, Extion, ".") = 0 Then

Dim reg As Microsoft.Win32.RegistryKey = Microsoft.Win32.Registry.ClassesRoot

Dim reg2 As Microsoft.Win32.RegistryKey = reg.CreateSubKey(Extion)

Extion = My.Computer.FileSystem.GetFileInfo(FilePath).Name + Extion

reg2.SetValue("", Extion)

reg2.Flush()

reg2 = reg.CreateSubKey(Extion + "\Shell\Open\command")

FilePath = Chr(34) + FilePath + Chr(34) + " " + Chr(34) + "%1" + Chr(34)

reg2.SetValue("", FilePath)

reg2.Flush()

reg.Close()

Return True

End If

End If

End If

Return False

End Function

以上内容摘自:http://blog.163.com/shikang999@126/blog/static/17262489620111722025573/

通过阅读此段代码,只要读取注册表中classroot中是否有指定后缀名的节点即可确定是否有对应的文件关联。

主要代码:

if(Microsoft.Win32.Registry.ClassesRoot.OpenSubKey(".txt")==null)

{

MessageBox("无文本的默认打开程序");

}

。net 添加或获取文件关联的更多相关文章

  1. macOS上实现Qt应用程序做文件关联打开

    一.背景介绍 用Qt开发的应用程序要实现文件关联,双击时用默认关联的程序打开文件,在Windows上这个功能非常容易实现.Windows应用程序在安装的时候可以在注册表中写入相关的键值对.打开文件的时 ...

  2. C#获取文件类型

    Form1.cs using System;using System.Collections.Generic;using System.ComponentModel;using System.Data ...

  3. 通过源码了解ASP.NET MVC 几种Filter的执行过程 在Winform中菜单动态添加“最近使用文件”

    通过源码了解ASP.NET MVC 几种Filter的执行过程   一.前言 之前也阅读过MVC的源码,并了解过各个模块的运行原理和执行过程,但都没有形成文章(所以也忘得特别快),总感觉分析源码是大神 ...

  4. iOS Category 添加属性实现原理 - 关联对象

    iOS Category 添加属性实现原理 - 关联对象 RunTime为Category动态关联对象 使用RunTime给系统的类添加属性,首先需要了解对象与属性的关系.对象一开始初始化的时候其属性 ...

  5. Deepin Linux下为Wine创建文件关联

    在Deepin Linux下,默认地,使用apt安装的Wine并没有创建文件关联,这使得在文件管理器中双击exe等Windows可执行文件时,不能直接运行.为此,必须手动在桌面环境中创建文件关联. 文 ...

  6. delphi 动态获取文件类型的图标

    delphi 动态获取文件类型的图标.txt我不奢望什么,只希望你以后的女人一个不如一个.真怀念小时候啊,天热的时候我也可以像男人一样光膀子!在应用程序的编写中,组合框(ComboBox).列表框(L ...

  7. Windows Store App JavaScript 开发:获取文件和文件夹列表

    在应用程序中有时可能需要获取用户库中的内容,以便执行相关的操作.如果要获取某个用户库中的内容,需要先获取到这个用户库,获得用户库可以通过Windows.Storage命名空间中的KnownFolder ...

  8. windows文件关联、打开方式列表之修改注册表攻略

    这里全是修改注册表的方式.网上找了半天,有的仅有添加文件关联的方法,却没有添加到打开方式列表里面的方法:有的有添加到文件列表的方法,却是使 用控制面板->文件夹选项的.好难得才找齐所有,从添加文 ...

  9. Ubuntu修改文件关联

    * 在system setting>details中可以设置一部分文件关联,很弱很破. * 右键open with只能临时选择打开方式,并且可选的打开方式十分有限.如果是自己编的程序,在列表中没 ...

随机推荐

  1. UIView常用的一些方法小记之setNeedsDisplay和setNeedsLayout

    1,UIView的setNeedsDisplay和setNeedsLayout方法 首先两个方法都是异步执行的.而setNeedsDisplay会调用自动调用drawRect方法,这样可以拿到  UI ...

  2. 利用Manacher算法寻找字符串中的最长回文序列(palindrome)

    寻找字符串中的最长回文序列和所有回文序列(正向和反向一样的序列,如aba,abba等)算是挺早以前提出的算法问题了,最近再刷Leetcode算法题的时候遇到了一个(题目),所以就顺便写下. 如果用正反 ...

  3. sysbench压力测试工具简介和使用(一)

    sysbench压力测试工具安装和参数介绍 一.sysbench压力测试工具简介: sysbench是一个开源的.模块化的.跨平台的多线程性能测试工具,可以用来进行CPU.内存.磁盘I/O.线程.数据 ...

  4. oracle的char和varchar类型

    源地址:https://zhidao.baidu.com/question/140310197.html varchar与char的区别就在于是否可变长度.char(5)就是定义一个5个字符长度的字符 ...

  5. 转:WIN7上搭建Windows Phone 8 开发环境——VMware Workstation下Win8 “无法安装Hyper-V, 某个虚拟机监控程序正在运行”问题解决的办法

    转自:http://www.cnblogs.com/shaddock2013/p/3155024.html 最近在试着在Windows 7上搭建Windows Phone 8的开发调试环境,使用的是V ...

  6. MFCButton Memory leak(内存泄露问题)

    http://m.blog.csdn.net/blog/haoekin/8851219 1.无法显示右边箭头的问题 无论怎么折腾都没显示不出来,微软给的示例又能显示,度娘和谷歌也都不知道,经过不断地探 ...

  7. 返回记录结构时,如果需要返回为nil时 应该怎么办。

  8. C#算法之向一个集合中插入随机不重复的100个数

    一道非常经典的C#笔试题: 需求:请使用C#将一个长度为100的int数组,插入1-100的随机数,不能重复,要求遍历次数最少. 1.最简单的办法 var rd = new Random(); Lis ...

  9. ORACLE 数据块dump

    1. rdba(Tablespace relative database block address) 是相对数据块地址,是数据所在的地址,rdba可就是rowid 中rfile#+block#. 根 ...

  10. sql left join、right join、inner join

    left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录inner join(等值连接) 只 ...