Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/visual-studio-2008/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 以不同格式复制和粘贴_C# - Fatal编程技术网

C# 以不同格式复制和粘贴

C# 以不同格式复制和粘贴,c#,C#,我有一个datagrid,我希望能够将其复制并粘贴到excel中。非常常见的情况。我实现了复制和粘贴功能。但是,这个应用程序有几个数据网格,我想防止用户尝试将数据从一个网格复制到另一个网格,因为数据是不同的 我可以将这些网格中的对象序列化为我想要的任何格式,因此添加某种元数据说“这些数据只进入该网格”是微不足道的。但我无法添加元数据,因为这样它就会显示在excel中。这个问题有什么解决方案可以让我在应用程序中以一种格式粘贴数据,但excel仍能正确处理吗?如果你看一下,你可以设置文本,但你还可以

我有一个datagrid,我希望能够将其复制并粘贴到excel中。非常常见的情况。我实现了复制和粘贴功能。但是,这个应用程序有几个数据网格,我想防止用户尝试将数据从一个网格复制到另一个网格,因为数据是不同的

我可以将这些网格中的对象序列化为我想要的任何格式,因此添加某种元数据说“这些数据只进入该网格”是微不足道的。但我无法添加元数据,因为这样它就会显示在excel中。这个问题有什么解决方案可以让我在应用程序中以一种格式粘贴数据,但excel仍能正确处理吗?

如果你看一下,你可以设置文本,但你还可以用它做很多事情。使用剪贴板要做的大多数高级工作都是围绕一对例程“SetDataObject”和“GetDataObject”展开的。要将其用于多种格式,可以指定:

var serializableObject = new MyObject();

var clipData = new DataObject();
clipData.SetData(DataFormats.Text, "abcdefg");
clipData.SetData("CustomFormat", serializableObject);
Clipboard.SetDataObject(data);
完成此操作后,您可以通过反转此操作并从自定义格式请求数据,从剪贴板获取数据。简单地说,反向调用如下所示:

var clipData = (DataObject)Clipboard.GetDataObject();
var myObject = clipData.GetData("CustomFormat") as MyObject;
有关Microsoft提供的更完整示例,请参阅以下页面:。只要看看底部,它解释了多种格式的使用

希望这有帮助。祝你好运