我有一个数据网格,我希望能够复制和粘贴到excel.很常见的情况.我实现了复制和粘贴功能.但是,这个应用程序有几个datagrids,我想阻止用户尝试将数据从一个网格复制到另一个网格,因为数据不同.
我可以将这些网格中的对象序列化为我想要的任何格式,因此添加一些"只有这个数据才能进入该网格"的元数据是微不足道的.但是我无法添加元数据,因为它会显示在excel中.是否有一些解决方案可以让我在我的应用程序中以一种格式粘贴数据,但是excel仍能正确处理?
如果你看一下剪贴板类,你可以设置文本,但你可以用它做更多的事情.您希望使用剪贴板执行的大多数高级操作都围绕一对例程"SetDataObject"和"GetDataObject".要使用多种格式,您可以指定:
var serializableObject = new MyObject();
var clipData = new DataObject();
clipData.SetData(DataFormats.Text, "abcdefg");
clipData.SetData("CustomFormat", serializableObject);
Clipboard.SetDataObject(data);
Run Code Online (Sandbox Code Playgroud)
完成此操作后,您可以通过反转并从自定义格式请求数据来从剪贴板中恢复数据.简而言之,反向调用如下:
var clipData = (DataObject)Clipboard.GetDataObject();
var myObject = clipData.GetData("CustomFormat") as MyObject;
Run Code Online (Sandbox Code Playgroud)
有关Microsoft的更完整示例,请参阅此页面:http://msdn.microsoft.com/en-us/library/637ys738(v = vs.110).aspx.只需查看底部,它解释了多种格式的使用.
希望这可以帮助.祝你好运!
| 归档时间: |
|
| 查看次数: |
160 次 |
| 最近记录: |