当前位置: 首页 > article >正文

68.浏览文件并选择文件 C#例子 WPF例子

OpenFileDialog是一个常用的对话框,允许用户浏览文件系统并选择文件。OpenFileDialog.ShowDialog()方法用于显示这个对话框,并且它会以模态方式运行,这意味着用户必须关闭对话框才能继续与应用程序的其他部分交互。

该代码会打开代码所在路径,你可以在里面创建文件夹,和文件,然后选中。文本框中就会填入选中文件的相对路径。

代码展示:

using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using Microsoft.Win32;
using System.IO;

namespace 路径填入
{
    /// <summary>
    /// Interaction logic for MainWindow.xaml
    /// </summary>
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
        }

        private void BrowseButton_Click(object sender, RoutedEventArgs e)
        {
            string baseDirectory = AppDomain.CurrentDomain.BaseDirectory;

            OpenFileDialog openFileDialog = new OpenFileDialog();
            openFileDialog.Filter = "All files (*.*)|*.*"; // 可以根据需要设置文件过滤
            openFileDialog.InitialDirectory = baseDirectory; // 设置初始目录

            if (openFileDialog.ShowDialog() == true)
            {
                // 将选择的文件路径填入文本框
                string relativePath = System.IO.Path.GetRelativePath(baseDirectory, openFileDialog.FileName);

                FilePathTextBox.Text = relativePath;
            }
        }
    }
}



<Window x:Class="路径填入.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:路径填入"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid>
        <TextBox x:Name="FilePathTextBox" Width="300" Height="30" Margin="10"/>
        <Button Content="浏览" Click="BrowseButton_Click" Width="80" Height="30" Margin="350,0,0,0"/>
    </Grid>
</Window>


http://www.kler.cn/a/535402.html

相关文章:

  • 使用 CSS 实现透明效果
  • 6种MySQL高可用方案对比分析
  • 19C RAC在vmware虚拟机环境下的安装
  • React 第二十二节 useSyncExternalStore Hook 常见问题及用法详解
  • VMware下Linux和macOS遇到的一些问题总结
  • SpringSecurity密码编码器:使用BCrypt算法加密、自定义密码编码器
  • 在K8S中,如何解决SVC容灾问题?
  • 想品客老师的第十二天:异步和promise
  • 图片PDF区域信息批量提取至Excel,基于QT和阿里云api的实现方案
  • Unity 简易的UI框架
  • C和Rust的一些区别
  • C中静态库和动态库的使用
  • 数据治理项目为什么沦为了PPT工程?
  • 2025.2.6(c++杂项补充及qt基础介绍)
  • Vue Dom截图插件,截图转Base64 html2canvas
  • H5+CSS+JS制作好看的轮播图
  • OSPF基础(2):数据包详解
  • 51单片机07 串口通信
  • 【C语言】常量指针和指针常量,指针数组和数组指针,指针函数和函数指针怎么区分?
  • vue2-nextTick
  • JAVA面试框架篇
  • 注册中心不知选哪个?Zookeeper、Eureka、Nacos、Consul和Etcd 5种全方位剖析对比
  • Python利用VideoCapture和FFmpeg读取多个rtsp流性能的比较
  • idea整合deepseek实现AI辅助编程
  • 【React】表单校验:从基础到集成库
  • Chapter 4-1. Troubleshooting Congestion in Fibre Channel Fabrics