1. 程式人生 > 其它 >C# 讀取excel剪下板中的的xml資料,防止資料格式化精度丟失

C# 讀取excel剪下板中的的xml資料,防止資料格式化精度丟失

c#讀取剪下板資料的時候,通常讀取字串:var txt = Clipboard.GetText();但此時可能精度丟失,比如excel中,資料是:1.3213216532132,但是格式保留2個精度。

此時如果直接用文字讀取剪下板,讀取到的是格式化後的結果,即1.32。這時就丟失了精度。如下圖。

為了避免精度丟失,可以採用讀取xml格式的剪下板資料,這樣精度就可以保證了。

程式碼如下:

var clipboard = Clipboard.GetDataObject();
            string XmlFmt = "XML Spreadsheet";
            if (!clipboard.GetDataPresent(XmlFmt))
            {
                return null;
            }
            var clipData = clipboard.GetData(XmlFmt);
            StreamReader streamReader = new StreamReader((MemoryStream)clipData);
            streamReader.BaseStream.SetLength(streamReader.BaseStream.Length - 1);

            string xmlText = streamReader.ReadToEnd();

            XmlDocument xmlDocument = new XmlDocument();
            xmlDocument.LoadXml(xmlText);

            XmlNamespaceManager nsmgr = new XmlNamespaceManager(xmlDocument.NameTable);

            nsmgr.AddNamespace("o", "urn:schemas-microsoft-com:office:office");
            nsmgr.AddNamespace("x", "urn:schemas-microsoft-com:office:excel");
            nsmgr.AddNamespace("ss", "urn:schemas-microsoft-com:office:spreadsheet");
            var tbRows = xmlDocument.SelectNodes("//ss:Worksheet/ss:Table/ss:Row", nsmgr);

            var maxColumnCount = GetMaxColumnCount(tbRows, nsmgr);

            StringBuilder resultString = new StringBuilder();
            int rowIndex = 0;
            foreach (XmlNode tbRow in tbRows)
            {
                rowIndex++;
                if (tbRow.Attributes["ss:Index"] == null)
                {
                    AddRowCells(tbRow, nsmgr, resultString, maxColumnCount);
                }
                else
                {
                    var rowIndexAttr = int.Parse(tbRow.Attributes["ss:Index"].Value);
                    while (rowIndex < rowIndexAttr)
                    {
                        for (int i = 0; i < maxColumnCount; i++)
                        {
                            resultString.Append("\t");
                        }

                        rowIndex++;
                        resultString.Append("\r\n");
                    }

                    //新增row
                    AddRowCells(tbRow, nsmgr, resultString, maxColumnCount);
                }
                resultString.Append("\r\n");
            }

            var txt = resultString.ToString();
            return txt;

  

原始碼如下:https://files.cnblogs.com/files/congqiandehoulai/2021-10-20-winform%E8%AF%BB%E5%8F%96excel%E7%B2%98%E8%B4%B4%E6%9D%BF.rar

參考文件:

https://stackoverflow.com/questions/8614910/paste-from-excel-into-c-sharp-app-retaining-full-precision

https://stackoverflow.com/questions/43793360/how-to-use-clipboard-to-copy-data-from-excel-sheet-to-datatable