以不同格式复制和粘贴

时间:2014-01-28 22:31:48

标签: c#

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

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

1 个答案:

答案 0 :(得分:5)

如果查看clipboard class,您可以设置文本,但也可以使用它进行更多操作。您希望使用剪贴板执行的大多数高级操作都围绕一对例程“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的更完整示例,请参阅此页:http://msdn.microsoft.com/en-us/library/637ys738(v=vs.110).aspx。只需看一下它解释多种格式使用的底部。

希望这会有所帮助。祝你好运!

相关问题