当前位置: 首页>>代码示例>>C#>>正文


C# Row.Descendants方法代码示例

本文整理汇总了C#中Row.Descendants方法的典型用法代码示例。如果您正苦于以下问题:C# Row.Descendants方法的具体用法?C# Row.Descendants怎么用?C# Row.Descendants使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Row的用法示例。


在下文中一共展示了Row.Descendants方法的9个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: GetExcelCellEnumerator

		private IEnumerator<Cell> GetExcelCellEnumerator(Row row)
		{
			int currentCount = 0;
			foreach (Cell cell in row.Descendants<Cell>())
			{
				string columnName = GetColumnName(cell.CellReference);

				int currentColumnIndex = ConvertColumnNameToNumber(columnName);

				for (; currentCount < currentColumnIndex; currentCount++)
				{
					var emptycell = new Cell()
					{
						DataType = null,
						CellValue = new CellValue(string.Empty)
					};
					yield return emptycell;
				}

				yield return cell;
				currentCount++;
			}
		}
开发者ID:slaq777,项目名称:lmsystem,代码行数:23,代码来源:SLExcelReader.cs

示例2: createColumns

        private void createColumns(DataTable dt,Row row)
        {
            _colNameMapping = new Dictionary<string, string>();
            var cells = row.Descendants<Cell>();

            foreach (var cell in cells)
            {
                string value = getCellValue(cell);
                string colHeader = Regex.Split(cell.CellReference.Value, @"\d+").First();
                _colNameMapping.Add(colHeader, value);
                DataColumn dc = new DataColumn(colHeader);
                dt.Columns.Add(dc);
            }
        }
开发者ID:Jason-Brody,项目名称:Young,代码行数:14,代码来源:ExcelHelper.cs

示例3: addRow

        private void addRow(DataTable dt,Row row)
        {
            DataRow dr = dt.NewRow();

            foreach (var cell in row.Descendants<Cell>())
            {
                string rowHeader = Regex.Split(cell.CellReference.Value, @"\d+").First();
                if (_colNameMapping.ContainsKey(rowHeader))
                {
                    dr[rowHeader] = getCellValue(cell);
                }

            }

            dt.Rows.Add(dr);
        }
开发者ID:Jason-Brody,项目名称:Young,代码行数:16,代码来源:ExcelHelper.cs

示例4: ValidateCellReferences

        /// <summary>
        /// Validates that the cell references in the target row are correctly synchronized to
        /// the index.
        /// </summary>
        /// <param name="toValidate">The row to validate.</param>
        /// <exception cref="ArgumentException">Thrown if the row has some invalid cell references
        /// inside it. This can be fixed by calling <see cref="SyncCellReferencesToRowIndex"/> on the
        /// row.</exception>
        private static void ValidateCellReferences(Row toValidate)
        {
            var cellDict = new Dictionary<string, Cell>();
            foreach (var cell in toValidate.Descendants<Cell>())
            {
                if (cellDict.ContainsKey(cell.CellReference.InnerText))
                {
                    throw new ArgumentException("Duplicate cell reference detected at cell: " + cell.CellReference.InnerText);
                }

                cellDict[cell.CellReference.InnerText] = cell;
            }

            // Make sure the cell row indices are correct.
            var pattern = @"[a-z]+" + toValidate.RowIndex + "{1}";
            var regex = new Regex(pattern, RegexOptions.Compiled | RegexOptions.IgnoreCase);
            foreach (var key in cellDict.Keys)
            {
                if (!regex.IsMatch(key))
                {
                    throw new ArgumentException("Invalid cell reference detected at cell: " + key + ". Regex: " + pattern);
                }
            }
        }
开发者ID:jduv,项目名称:IndexML,代码行数:32,代码来源:LinkedListBasedSheetDataIndexer.cs

示例5: SyncCellReferencesToRowIndex

        /// <summary>
        /// Synchronizes cell references to a row's index.
        /// </summary>
        /// <param name="toSync">The row to synchronize.</param>        
        private static void SyncCellReferencesToRowIndex(Row toSync)
        {
            foreach (var cell in toSync.Descendants<Cell>())
            {
                cell.CellReference.InnerText = Regex.Replace(
                    cell.CellReference.InnerText,
                    CellReference.SingleCellRefRegexStringStrict,
                    @"${col}" + toSync.RowIndex,
                    RegexOptions.Compiled | RegexOptions.IgnoreCase);
            }

            ValidateCellReferences(toSync);
        }
开发者ID:jduv,项目名称:IndexML,代码行数:17,代码来源:LinkedListBasedSheetDataIndexer.cs

示例6: GetCells

        public IEnumerable<Cell> GetCells(Row xRow)
        {
            var newRow = new List<Cell>();

            int columnIndex = 0;
            foreach (Cell cell in xRow.Descendants<Cell>())
            {
                // Gets the column index of the cell with data
                int? columnIndexFromName = GetColumnIndexFromName(GetColumnName(cell.CellReference));
                if (columnIndexFromName != null)
                {
                    var cellColumnIndex = (int)columnIndexFromName;

                    if (columnIndex < cellColumnIndex)
                    {
                        do
                        {
                            newRow.Add(new Cell());
                            //tempRow[columnIndex] = //Insert blank data here;
                            columnIndex++;
                        }
                        while (columnIndex < cellColumnIndex);
                    }
                }
                newRow.Add(cell);
                columnIndex++;
            }

            return newRow;
        }
开发者ID:sympletech,项目名称:SympleLib,代码行数:30,代码来源:OpenXLRow.cs

示例7: IsValidRowDataTemplate

        private static bool IsValidRowDataTemplate(Row row, List<Cell> headerCells)
        { 
            if (row.RowIndex <= 1) //At least greater than 1 (row 1 must be the header one)
                return false;

            var cells = row.Descendants<Cell>().ToList();

            if (cells.Count < headerCells.Count) //Must have at least as many cells as the header row to have a template cell for all data columns
                return false;

            string headerLastCellReference = headerCells[headerCells.Count - 1].CellReference;
            string dataCellReference = cells[headerCells.Count - 1].CellReference;
            
            //they must be in the same column
            //If cellReferences of HeaderCell and DataCell differ only in the number they are on the same column
            var firstDifferentCharacter = headerLastCellReference.Zip(dataCellReference).FirstEx(t => t.Item1 != t.Item2);
            int number;
            return int.TryParse(firstDifferentCharacter.Item1.ToString(), out number);
        }
开发者ID:JackWangCUMT,项目名称:extensions,代码行数:19,代码来源:ExcelGenerator.cs

示例8: AddRow

 private void AddRow(Row descendant)
 {
     MyRows.Add(new ExcelOpenXmlRow(descendant.Descendants<Cell>(), SharedStrings));
 }
开发者ID:mpbill,项目名称:ExcelOpenXmlReader,代码行数:4,代码来源:ExcelOpenXmlReader.cs

示例9: GetRowCells

        ///<summary>returns an empty cell when a blank cell is encountered
        ///</summary>
        private static IEnumerable<Cell> GetRowCells(Row row)
        {
            int currentCount = 0;

            foreach(Cell cell in row.Descendants<DocumentFormat.OpenXml.Spreadsheet.Cell>())
            {
                int currentColumnIndex = GetColumnIndexFromName(cell.CellReference);

                for(; currentCount < currentColumnIndex; currentCount++)
                {
                    yield return new DocumentFormat.OpenXml.Spreadsheet.Cell();
                }

                yield return cell;
                currentCount++;
            }
        }
开发者ID:jkshan,项目名称:DataImporter,代码行数:19,代码来源:ExcelParser.cs


注:本文中的Row.Descendants方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。