Exemple #1
0
        public int DoMerge(int currentRowIndex, Range currentCellRange)
        {
            if (currentCellRange == null)
            {
                return(0);
            }
            lastCellRange = currentCellRange;

            return(RangeHelper.MergeRanges(currentCellRange, mOption));
        }
Exemple #2
0
        internal object GetValueByIndex(int rowIndex, DataTable table)
        {
            if (lastUsedTable != table)
            {
                lastUsedColIndex = table.Columns.IndexOf(tplValueColName);
                lastUsedTable    = table;
            }

            return(RangeHelper.GetColValue(table, rowIndex, lastUsedColIndex));
        }
        public void Clear()
        {
            sheet.RemoveRange(RangeHelper.GetEntireCol(sheet, 1));
            sheet.RemoveRange(RangeHelper.GetEntireCol(sheet, 1));
            //.Delete(XlDeleteShiftDirection.xlShiftToLeft);

            for (int i = 1; i < startRowIndex; i++)
            {
                sheet.RemoveRange(RangeHelper.GetEntireRow(sheet, 1));
                // .Delete(XlDeleteShiftDirection.xlShiftUp);
            }
        }
Exemple #4
0
        private void RefreshLineTplRanges(TplBlock block, int colCount)
        {
            for (int i = 0; i < block.lineList.Count; i++)
            {
                TplLine line = block.lineList [i];

                line.tplRange = RangeHelper.GetRange(line.tplRange.Worksheet,
                                                     line.tplRange.Column,
                                                     line.tplRange.Row,
                                                     line.tplCellCount + insertCount,
                                                     colCount
                                                     );
                line.tplCellCount += colCount;
            }
        }
Exemple #5
0
        public void UpdateRowData(GroupDataHolder holder, int currentRowIndex, System.Data.DataTable table, int valueRowIndex)
        {
            int cellColIndex = cellList[0].lastColIndex;

            for (int i = 0; i < cellList.Count; i++)
            {
                TplCell cell = cellList[i];
                if (cell.formula != null)
                {
                    Range cellRange = RangeHelper.GetCell(tplRange.Worksheet, cellColIndex, currentRowIndex);

                    cell.WriteCell(tpl, holder, cellRange, table, valueRowIndex);
                }
                cellColIndex += cell.acrossColumns;
            }
        }
Exemple #6
0
        private int IsNeedNewCol(int currentRowIndex, GroupDataHolder holder, System.Data.DataTable table, int valueIndex)
        {
            object [] vList = new object[groupColList.Count];
            if (lastUsedTable != table)
            {
                lastUsedTable = table;
                // Clear to -1 ;
                for (int i = 0; i < groupColIndexList.Count; i++)
                {
                    groupColIndexList [i] = table.Columns.IndexOf(groupColList [i]);
                }
            }
            for (int i = 0; i < groupColList.Count; i++)
            {
                /* string colName = groupColList [i] ;  */

                vList[i] = RangeHelper.GetColValue(table, valueIndex, groupColIndexList[i]);
            }

            for (int i = 0; i < lastValueMap.Count; i++)
            {
                object[] lvList = lastValueMap [i];

                if (CompareArray(vList, lvList))
                {
                    return(-1);
                }
            }

            // Save new value list
            lastValueMap.Add(vList);

            /* for (int i = 0; i < cellList.Count; i++)
             * {
             *      TplCell cell = cellList[i];
             *      if (cell.align != GroupAlign.hGroup)
             *              continue ;
             *      if (! cell.IsNeedNewCell(holder, InsertOption.afterChange, cell.lastColIndex, currentRowIndex, table, valueIndex))
             *              index = i ;
             *
             * }
             */
            return(0);
        }
Exemple #7
0
        private void UpdateLine(int currentRowIndex, GroupDataHolder holder, int startIndex, DataTable table, int valueRowIndex, MergeOption mo, bool updateMergeOnly)
        {
            int cellColIndex = cellList[0].lastColIndex;

            for (int i = 0; i < cellList.Count; i++)
            {
                TplCell cell = cellList[i];

                int merge = 0;

                if (cell.mOption == mo &&
                    (                // merge before.
                        i < startIndex ||
                        // merge after. next line is new line
                        (i >= startIndex && (iOption & InsertOption.BeforeChange) != 0) ||
                        // ignore group align option.
                        cell.align == GroupAlign.none))
                // do Merge
                {
                    Range cellRange = RangeHelper.GetCell(tplRange.Worksheet, cellColIndex, currentRowIndex);

                    merge = cell.DoMerge(currentRowIndex, cellRange);
                }

                if (merge == 0 && !updateMergeOnly)
                {
                    if (cell.formula == null)
                    {
                        Range cellRange = RangeHelper.GetCell(tplRange.Worksheet, cellColIndex, currentRowIndex);

                        cell.WriteCell(tpl, holder, cellRange, table, valueRowIndex);
                    }
                }

                /*
                 * else
                 *      // todo: Remove this noused line?
                 *      cell.lastGroupedValue = cell.GetValue(holder, table, valueRowIndex);
                 */
                cellColIndex += cell.acrossColumns;
            }
        }
Exemple #8
0
        public void MergeVGroupCells()
        {
            for (int i = 0; i < lineList.Count; i++)
            {
                TplLine line = lineList[i];

                /*
                 * if (!line.containsHGroup)
                 *      continue;
                 */
                int colIndex = line.colIndex;
                for (int j = 0; j < line.cellList.Count; j++)
                {
                    TplCell cell = line.cellList [j];
                    if (cell.mOption != MergeOption.Up ||
                        (cell.align != GroupAlign.none &&
                         cell.align != GroupAlign.always))
                    {
                        colIndex += cell.acrossColumns;
                        continue;
                    }
                    for (int k = 0; k < line.insertedRowList.Count; k++)
                    {
                        int rowIndex = line.insertedRowList[k];

                        CellRange range = RangeHelper.GetCell(tplRange.Worksheet, colIndex, rowIndex);

                        if (!range.HasMerged)
                        {
                            RangeHelper.MergeRanges(range, MergeOption.Up);
                        }
                    }

                    colIndex += cell.acrossColumns;
                }
            }
        }
Exemple #9
0
        public void InsertColumn(TplBlock block, GroupDataHolder holder, DataTable table, int valueIndex, bool hasData)
        {
            // do insert
            if (insertCount > 0)
            {
                if (hasData)
                {
                    // block.startRowIndex ;
                    Range colRange = RangeHelper.GetRange(tplRange.Worksheet,
                                                          startColIndex + insertCount - gCols, block.startRowIndex,
                                                          gCols, block.rowCount);
                    // Insert new ;
                    RangeHelper.InsertCopyRange(tplRange.Worksheet, colRange,
                                                gCols, block.rowCount,
                                                startColIndex + insertCount, block.startRowIndex,
                                                XlInsertShiftDirection.xlShiftToRight, tplLastColCount);
                }
                // Insert new Col in Template.
                Range tplColRange = RangeHelper.GetRange(tplRange.Worksheet,
                                                         startColIndex + insertCount - gCols, block.tplRange.Row,
                                                         gCols, block.tplRowCount);

                RangeHelper.InsertCopyRange(tplRange.Worksheet, tplColRange,
                                            gCols, block.tplRowCount,
                                            startColIndex + insertCount, tplColRange.Row,
                                            XlInsertShiftDirection.xlShiftToRight, tplLastColCount);
                // Refresh Line.TplRange ;
                RefreshLineTplRanges(block, gCols);

                block.tplColumCount += gCols;
                block.colCount      += gCols;
            }


            // Insert cell into exsit lineList.
            for (int lineIndex = 0; lineIndex < block.lineList.Count; lineIndex++)
            {
                TplLine line = block.lineList [lineIndex];

                for (int j = 0; j < gCols; j++)
                {
                    int cellIndex = startCellIndex + (insertCount > 0 ? (insertCount - gCols) : 0) + j;

                    TplCell cell = line.cellList [cellIndex];

                    /* if (cell.lastColIndex != nextCloIndex - (insertCount > 0 ? 1 : 0)) */
                    // if (cell.lastColIndex < nextCloIndex || cell.lastColIndex >= nextCloIndex + gCols)
                    //  continue ;

                    //	if (lineIndex == 2)
                    //		lineIndex = 2 ;

                    if (insertCount > 0)
                    {
                        cell = cell.Copy();
                        cell.lastColIndex += gCols;

                        line.cellList.Insert(cellIndex + gCols, cell);
                    }

                    if (cell.formula != null)
                    {
                        for (int keyIndex = 0; keyIndex < cell.formula.keyList.Count; keyIndex++)
                        {
                            GroupValueSearchKey gkey = cell.formula.keyList[keyIndex];
                            SearchKey           key  = gkey.key;
                            while (key != null)
                            {
                                if (IsGroupedColumn(key.colName))
                                {
                                    key.keyValue     = RangeHelper.GetColValue(table, valueIndex, key.colName);
                                    key.isFixedValue = true;
                                }
                                key = key.nextKey;
                            }

                            block.gkeyList.Add(gkey.Copy());
                            if (gkey.key != null)
                            {
                                gkey.key.FillKey(table, valueIndex);
                            }

                            block.holder.AddValue(block.countedMap, gkey, table, valueIndex);
                        }
                    }
                    else
                    if (cell.hgOption != InsertOption.never)
                    {
                        cell.tplTextContent = Convert.ToString(cell.GetValueByIndex(valueIndex, table));
                    }

                    cell.align = GroupAlign.none;

                    Console.WriteLine("Inserted hg Line[" + lineIndex + "]cell[" + cellIndex + "] = " + cell.formula);

                    /* update Row Value */
                    if (lineIndex < block.rowCount)
                    {
                        Range cellRange = RangeHelper.GetCell(tplRange.Worksheet, startColIndex + (insertCount /* == 0 ? 0 : insertCount - 1*/) + j,
                                                              block.startRowIndex + lineIndex);

                        cell.WriteCell(tpl, holder, cellRange, table, valueIndex);
                    }
                }
            }
            // Console.WriteLine ("---- End of " + valueIndex);
            // increment next

            nextCloIndex += gCols;
            insertCount  += gCols;
        }
Exemple #10
0
        public void InsertOneColumn(TplBlock block, int colIndex, GroupDataHolder holder, DataTable table, int valueIndex, bool hasData)
        {
            if (hasData)
            {
                // block.startRowIndex ;
                Range colRange = RangeHelper.GetRange(tplRange.Worksheet,
                                                      startColIndex + colIndex, block.startRowIndex,
                                                      1, block.rowCount);
                // Insert new ;
                RangeHelper.InsertCopyRange(tplRange.Worksheet, colRange,
                                            1, block.rowCount,
                                            startColIndex + gCols + insertCount, block.startRowIndex,
                                            XlInsertShiftDirection.xlShiftToRight, tplLastColCount);
            }
            // Insert new Col in Template.
            Range tplColRange = RangeHelper.GetRange(tplRange.Worksheet,
                                                     startColIndex + colIndex, block.tplRange.Row,
                                                     1, block.tplRowCount);

            RangeHelper.InsertCopyRange(tplRange.Worksheet, tplColRange,
                                        1, block.tplRowCount,
                                        startColIndex + gCols + insertCount, tplColRange.Row,
                                        XlInsertShiftDirection.xlShiftToRight, tplLastColCount);
            // Refresh Line.TplRange ;
            RefreshLineTplRanges(block, 1);

            block.tplColumCount += 1;
            block.colCount      += 1;

            // Insert cell into exsit lineList.
            for (int lineIndex = 0; lineIndex < block.lineList.Count; lineIndex++)
            {
                TplLine line = block.lineList[lineIndex];

                int cellIndex = startCellIndex + colIndex;

                TplCell cell0 = line.cellList[cellIndex];

                TplCell cell = cell0.Copy();
                cell.lastColIndex += 1;


                line.cellList.Insert(startCellIndex + gCols + insertCount, cell);

                /*
                 * if (cell.useExcelFormula)
                 * {
                 *      cell.tplRange = cell0.tplRange ;
                 * }
                 */
                if (cell.formula != null)
                {
                    for (int keyIndex = 0; keyIndex < cell.formula.keyList.Count; keyIndex++)
                    {
                        GroupValueSearchKey gkey = cell.formula.keyList[keyIndex];
                        if (gkey.rKey == null)
                        {
                            SearchKey key0 = new SearchKey();
                            key0.colName = gkey.valueColName;

                            gkey.rKey = ReusedKey.FindReusedKey(key0);
                        }
                        SearchKey key = gkey.key;
                        while (key != null)
                        {
                            if (IsGroupedColumn(key.colName))
                            {
                                key.keyValue     = RangeHelper.GetColValue(table, valueIndex, key.colName);
                                key.isFixedValue = true;
                            }
                            key = key.nextKey;
                        }

                        block.gkeyList.Add(gkey.Copy());
                        if (gkey.key != null)
                        {
                            gkey.key.FillKey(table, valueIndex);
                        }

                        block.holder.AddValue(block.countedMap, gkey, table, valueIndex);
                    }
                }

                /*
                 * else if (cell.hgOption != InsertOption.never)
                 * {
                 *      // set fixed text
                 *      cell.tplTextContent = Convert.ToString(RangeHelper.GetColValue (table, valueIndex, cell.tplValueColName)) ;
                 * }
                 */

                cell.align = GroupAlign.none;

                Console.WriteLine("Inserted hg Line[" + lineIndex + "]cell[" + cellIndex + "] = " + cell.formula);

                /* update Row Value */
                if (lineIndex < block.rowCount)
                {
                    Range cellRange = RangeHelper.GetCell(tplRange.Worksheet, startColIndex + gCols + insertCount,
                                                          block.startRowIndex + lineIndex);

                    cell.WriteCell(tpl, holder, cellRange, table, valueIndex);
                }
            }
            // Console.WriteLine ("---- End of " + valueIndex);
            // increment next

            nextCloIndex += 1;
            insertCount++;
        }
Exemple #11
0
        private TplCloumn FindDColumn()
        {
            TplCloumn dcol = new TplCloumn();

            dcol.gCols = 0;

            for (int i = 0; i < lineList.Count; i++)
            {
                TplLine line = lineList [i];

                // int startIndex = -1 ;
                for (int j = 0; j < line.cellList.Count; j++)
                {
                    TplCell cell = line.cellList [j];

                    if (cell.align == GroupAlign.hGroup)
                    {
                        // Only One DColumn
                        if (dcol.gCols <= 0)
                        {
                            dcol.startCellIndex = j;
                            dcol.startColIndex  = cell.lastColIndex;
                        }

                        dcol.gCols++;
                    }
                }


                if (dcol.gCols > 0)
                {
                    break;
                }
            }

            if (dcol.gCols <= 0)
            {
                return(null);
            }

            dcol.tplLastColCount = tplColumCount - dcol.startCellIndex - dcol.gCols;
            if (dcol.tplLastColCount <= 0)
            {
                dcol.tplLastColCount = 1;
            }

            // find out gcells
            dcol.tplRange = RangeHelper.GetRange(tplRange.Worksheet, dcol.startColIndex
                                                 , tplRowCount, dcol.gCols, lineList.Count);

            for (int i = 0; i < lineList.Count; i++)
            {
                TplLine line = lineList [i];

                for (int j = 0; j < line.cellList.Count; j++)
                {
                    TplCell cell = line.cellList [j];

                    if (cell.align == GroupAlign.hGroup)
                    {
                        TplCell newCell = cell.Copy();
                        dcol.cellList.Add(newCell);

                        if (!dcol.groupColList.Contains(cell.tplGroupColName))
                        {
                            dcol.groupColList.Add(cell.tplGroupColName);
                            dcol.groupColIndexList.Add(-1);
                        }
                    }
                }
            }

            return(dcol);
        }
Exemple #12
0
        public void MergeHGroupCells()
        {
            for (int i = 0; i < lineList.Count; i++)
            {
                TplLine line = lineList [i];
                if (!line.containsHGroup)
                {
                    continue;
                }

                for (int j = 0; j < line.insertedRowList.Count; j++)
                {
                    int rowIndex = line.insertedRowList [j];

                    object lastValue = null;
                    int    colIndex  = dColumn.startColIndex;
                    // if (line.cellList [colIndex].mOption != MergeOption.Left)
                    //	continue ;
                    // ingore this line ;

                    for (int k = 0; k < dColumn.insertCount; k++)
                    {
                        Range  cell  = RangeHelper.GetCell(tplRange.Worksheet, colIndex, rowIndex);
                        object value = cell.Value2;


                        if (lastValue != null &&
                            Equals(lastValue, value))
                        {
                            /* remove after debug.
                             * if (colIndex == 27)
                             *      Console.WriteLine ("colINdex=27");
                             */
                            // clear
                            // judge if last row is last hgrouoped row.
                            if (i == lineList.Count - 1 || lineList [i + 1].containsHGroup)
                            {
                                RangeHelper.MergeRanges(cell, MergeOption.Left);
                            }
                            else
                            {
                                // check is this column first column in hgrouped columns.
                                if (k % dColumn.gCols > 0)
                                {
                                    RangeHelper.MergeRanges(cell, MergeOption.Left);
                                }
                            }
                        }

                        lastValue = value;
                        colIndex++;
                    }

                    // repair unmerged range
                    int afterIndex = dColumn.startCellIndex + dColumn.insertCount;
                    for (int k = afterIndex;
                         k < line.cellList.Count; k++)
                    {
                        TplCell cell = line.cellList [k];

                        if (cell.mOption == MergeOption.Left)
                        {
                            Range range = RangeHelper.GetCell(tplRange.Worksheet, colIndex, rowIndex);
                            RangeHelper.MergeRanges(range, MergeOption.Left);
                        }
                        colIndex += cell.acrossColumns;
                    }
                }
            }
        }
Exemple #13
0
        public int CreateDColumns(DataTable table)
        {
            if (dColumn == null)
            {
                return(0);
            }

            // Current colCount include gCols, so substract it.
            colCount -= dColumn.gCols;

            // try to insert dColumns into Template.
            // dColumn.CheckColumn ()
            if (table == null || table.Rows.Count <= 0)
            {
                return(0);
            }

            for (int i = 0; i < table.Rows.Count; i++)
            {
                dColumn.CheckEachColumn(this, holder, 0, table, i);
                // dColumn.InsertColumn (this, holder, table, i, false);
            }

            dCloumnsCreated = true;

            // remove data from template
            // Insert new Col in Template.
            Range tplColRange = RangeHelper.GetRange(tplRange.Worksheet,
                                                     dColumn.startColIndex + dColumn.gCols, tplRange.Row,
                                                     tplColumCount - dColumn.startCellIndex - dColumn.gCols - 1,
                                                     // 50,
                                                     tplRowCount);

            tplColRange.Copy(
                RangeHelper.GetRange(tplRange.Worksheet,
                                     dColumn.startColIndex, tplRange.Row,
                                     tplColumCount - dColumn.startCellIndex - dColumn.gCols - 1,
                                     // 50,
                                     tplRowCount), true, true);

            /*
             * RangeHelper.InsertCopyRange(tplRange.Worksheet, tplColRange,
             *                                                      tplColumCount - dColumn.startCellIndex - dColumn.gCols,
             *                          tplRowCount,
             *                                                      startColIndex , tplColRange.Row,
             *                                                      XlInsertShiftDirection.xlShiftToRight, tplColumCount);
             */
            tplColumCount -= dColumn.gCols;
            for (int i = 0; i < lineList.Count; i++)
            {
                TplLine line = lineList [i];

                line.cellList.RemoveRange(dColumn.startCellIndex, dColumn.gCols);
                line.tplCellCount -= dColumn.gCols;
                line.tplRange      = RangeHelper.GetRange(tplRange.Worksheet,
                                                          3, line.tplRange.Row,
                                                          tplColumCount, 1);
            }
            // Refresh Line.TplRange ;
            // RefreshLineTplRanges(block, 1);

            return(1);
        }
Exemple #14
0
        /*
         * private void ClearExcelReport(bool autoFit, string fileName, List<ReportSheetTemplate> tplList)
         * {
         *      bool reusedFlag = false;
         *      if (xlapp.Workbooks.Count > 0)
         *      {
         *              reusedFlag = true;
         *      }
         *      xlapp.Workbooks.Open(fileName,
         *                                                Missing.Value, Missing.Value, Missing.Value, Missing.Value,
         *                                                Missing.Value, Missing.Value, Missing.Value, Missing.Value,
         *                                                Missing.Value, Missing.Value, Missing.Value, Missing.Value,
         *                                                Missing.Value, Missing.Value);
         *
         *      xlapp.DisplayAlerts = false;
         *
         *      for (int i = 0; i < xlapp.ActiveWorkbook.Worksheets.Count &&
         *                                      i < tplList.Count; i++)
         *      {
         *              Worksheet worksheet = (Worksheet)xlapp.ActiveWorkbook.Worksheets[i + 1];
         *
         *              ReportSheetTemplate tpl = tplList[i];
         *              JoinTable(worksheet, tpl);
         *              // Clear Data
         *              Clear(worksheet, tpl.startRowIndex);
         *
         *              if (autoFit || tpl.autoFit)
         *              {
         *                      Range range = worksheet.get_Range("A1", "DZ1").EntireColumn;
         *                      range.AutoFit();
         *              }
         *              // .GetType ().GetMethod ("AutoFit").Invoke (range, new object[0]) ;
         *
         *      }
         *
         *      // remove warnning sheet.
         *
         *      IEnumerator e = xlapp.ActiveWorkbook.Worksheets.GetEnumerator();
         *      while (e.MoveNext())
         *      {
         *              Worksheet sheet = (Worksheet)e.Current;
         *
         *              if (sheet.Name.IndexOf("Warning") >= 0)
         *                      sheet.Delete();
         *      }
         *      ((_Worksheet)xlapp.ActiveWorkbook.Worksheets[1]).Activate();
         *      ((Worksheet)xlapp.ActiveWorkbook.Worksheets[1]).get_Range("A1", "A1").Activate();
         *      // only save activeWorkBook
         *      xlapp.ActiveWorkbook.Save();
         *      // only close activeWorkbook ;
         *      xlapp.ActiveWorkbook.Close(true, Missing.Value, Missing.Value);
         *      // xlapp.Workbooks.Close ();
         * }
         */
        public static void JoinTable(Spire.Xls.Worksheet sheet, ReportSheetTemplate tpl)
        {
            if (tpl.blockList.Count < 2)
            {
                return;
            }

            TplBlock firstBlock     = tpl.blockList [1];
            int      blockRow       = firstBlock.startRowIndex;
            int      blocklastColum = firstBlock.startColIndex + firstBlock.colCount

                                      /* -
                                       * (firstBlock.dColumn == null ? 0 : firstBlock.dColumn.gCols)*/;

            int joinedRows = 0;

            for (int i = 2; i < tpl.blockList.Count; i++)
            {
                TplBlock block = tpl.blockList [i];

                if (block.joinat >= 0 && block.rowCount > 0)
                {
                    // CopyRangeToFirstTable
                    CellRange range = RangeHelper.GetRange(sheet, block.startColIndex + block.joinat + 1,
                                                           block.startRowIndex - joinedRows,
                                                           block.colCount, block.rowCount);
                    range.Copy(
                        RangeHelper.GetRange(sheet, blocklastColum + 1, firstBlock.startRowIndex, block.colCount, block.rowCount));


                    /* range.EntireRow.Delete (Microsoft.Office.Interop.Excel.XlDeleteShiftDirection.xlShiftUp) ; */
                    // delete rows.
                    for (int k = 0; k < block.rowCount; k++)
                    {
                        sheet.DeleteRow(block.startRowIndex - joinedRows);
                    }

                    joinedRows += block.rowCount;
                    if (block.dColumn != null && block.dColumn.startCellIndex == block.joinat)
                    {
                        // Merge Joined Table Columns.
                        for (int j = 0; j < block.lineList.Count; j++)
                        {
                            TplLine line = block.lineList [j];

                            if (!line.containsHGroup)
                            {
                                continue;
                            }

                            Boolean hasMerged = false;
                            for (int k = 0; k < line.insertedRowList.Count; k++)
                            {
                                int rowIndex = line.insertedRowList [k];
                                rowIndex = rowIndex - block.startRowIndex + blockRow;

                                CellRange leftRange = RangeHelper.GetRange(sheet, blocklastColum, rowIndex, 1, 1);
                                if (leftRange.MergeArea != null)
                                {
                                    leftRange = RangeHelper.GetRange(sheet, leftRange.MergeArea.Column, leftRange.MergeArea.Row, 1, 1);
                                }
                                CellRange rightRange = RangeHelper.GetRange(sheet, blocklastColum + 1, rowIndex, 1, 1);
                                if (rightRange.MergeArea != null)
                                {
                                    rightRange = RangeHelper.GetRange(sheet, rightRange.MergeArea.Column, rightRange.MergeArea.Row, 1, 1);
                                }

                                if (leftRange.Text.Equals(rightRange.Text))
                                {
                                    // Merge

                                    RangeHelper.GetRange(sheet, leftRange.Column,
                                                         leftRange.Row,
                                                         rightRange.Column + rightRange.Columns.Length - leftRange.Column,

                                                         Math.Min(rightRange.Rows.Length, leftRange.Rows.Length)
                                                         ).Merge();

                                    hasMerged = true;
                                }
                            }

                            if (!hasMerged)
                            {
                                break;
                            }
                        }                 // end for
                    }                     // end if
                    blocklastColum += block.colCount - block.joinat;
                }
            }
        }
Exemple #15
0
        private void ClearReport(bool autoFit, Workbook book, List <ReportSheetTemplate> tplList)
        {
            for (int i = 0; i < book.Worksheets.Count &&
                 i < tplList.Count; i++)
            {
                Spire.Xls.Worksheet worksheet = book.Worksheets [i];

                ReportSheetTemplate tpl = tplList [i];
                JoinTable(worksheet, tpl);
                // Clear Data
                Clear(worksheet, tpl.startRowIndex);

                if (autoFit || tpl.autoFit)
                {
                    CellRange range = RangeHelper.GetRange(worksheet, 1, 15, 50, 100);
                    range.AutoFitColumns();


                    /*for (int j = 1; j < 100; j++)
                     * {
                     *      try
                     *      {
                     *              worksheet.AutoFitColumn (j);
                     *      }
                     *      catch (Exception e)
                     *      {
                     *              Console.Write (e) ;
                     *      }
                     * }
                     */
                }

                // .GetType ().GetMethod ("AutoFit").Invoke (range, new object[0]) ;
                // copy image

                /*for (int j = 0; tpl.pics != null &&
                 *              j < tpl.pics.Count &&
                 *              j < worksheet.Pictures.Count; j++)
                 * {
                 *      Rectangle pic = tpl.pics [i] ;
                 *
                 *
                 *      int tmp = worksheet.Pictures [i].TopRow ;
                 *      tmp = worksheet.Pictures[i].TopRowOffset;
                 *      tmp = worksheet.Pictures[i].LeftColumn;
                 *      tmp = worksheet.Pictures[i].LeftColumnOffset;
                 *      tmp = worksheet.Pictures [i].BottomRow ;
                 *      tmp = worksheet.Pictures [i].BottomRowOffset ;
                 *      tmp = worksheet.Pictures [i].RightColumn ;
                 *      tmp = worksheet.Pictures [i].RightColumnOffset ;
                 *
                 *      worksheet.Pictures [i].Left = pic.X ;
                 *      worksheet.Pictures [i].Top = pic.Y ;
                 *      worksheet.Pictures [i].Height = pic.Height ;
                 *      worksheet.Pictures [i].Width = pic.Width ;
                 *
                 * }*/
            }

            // remove warnning sheet.

/*
 *                      IEnumerator e = xlapp.ActiveWorkbook.Worksheets.GetEnumerator();
 *                      while (e.MoveNext())
 *                      {
 *                              Worksheet sheet = (Worksheet)e.Current;
 *
 *                              if (sheet.Name.IndexOf("Warning") >= 0)
 *                                      sheet.Delete();
 *                      }
 *                      ((_Worksheet)xlapp.ActiveWorkbook.Worksheets[1]).Activate ();
 *                      ((Worksheet)xlapp.ActiveWorkbook.Worksheets [1]).get_Range("A1", "A1").Activate();
 *                      // only save activeWorkBook
 *                      xlapp.ActiveWorkbook.Save ();
 *                      // only close activeWorkbook ;
 *                      xlapp.ActiveWorkbook.Close (true, Missing.Value, Missing.Value);
 *                      // xlapp.Workbooks.Close ();
 */
        }
        public static ReportSheetTemplate ParseTemplate(Worksheet sheet, int sheetIndex)
        {
            /* Range topRange = RangeHelper.GetRange (sheet, 1, 1, 1, 1).EntireColumn ; */
            ReportSheetTemplate tpl = new ReportSheetTemplate();

            tpl.sheet = sheet;

            // Load pics
            PicturesCollection pictures = sheet.Pictures;

            List <Rectangle> pics = new List <Rectangle>();

            for (int i = 0; i < pictures.Count; i++)
            {
                ExcelPicture picture = pictures [i];
                pics.Add(new Rectangle(picture.Left, picture.Top, picture.Width, picture.Height));
            }

            tpl.pics = pics;
            // clear pictures.
            sheet.Pictures.Clear();

            int lastValuedRowIndex = 1;

            for (int rowIndex = 1; rowIndex < MAX_ROW_COUNT; rowIndex++)
            {
                Range  range = RangeHelper.GetRange(sheet, 1, rowIndex, 1, 1);
                string text  = (string)range.Value2;
                if (string.IsNullOrEmpty(text))
                {
                    continue;
                }

                lastValuedRowIndex = rowIndex;

                if (text.Equals("sql", StringComparison.CurrentCultureIgnoreCase))
                {
                    // here is a SQL.
                    range = RangeHelper.GetRange(sheet, 2, rowIndex, 1, 1);
                    string tableName = range.Value2 as string;

                    if (string.IsNullOrEmpty(tableName))
                    {
                        continue;
                    }

                    range = RangeHelper.GetRange(sheet, 3, rowIndex, 1, 1);
                    string sql = range.Value2 as string;

                    if (string.IsNullOrEmpty(sql))
                    {
                        continue;
                    }

                    // add sheet prefix to tableName
                    if (tableName.IndexOf('.') < 0)
                    {
                        tableName = "S" + sheetIndex + "." + tableName;
                    }
                    tpl.sqlList [tableName] = sql;


                    continue;
                }

                Dictionary <string, string> blockParams = ParseKeyValuePair(text);

                TplBlock block = new TplBlock();

                block.startColIndex = 2;
                block.startRowIndex = rowIndex;
                block.colCount      = block.tplColumCount = int.Parse(blockParams ["cols"]);
                if (blockParams.ContainsKey("name"))
                {
                    block.name = blockParams ["name"];
                }
                else
                {
                    block.name = "S" + sheetIndex + ".block" + (tpl.blockList.Count + 1);
                }

                // parse chart params
                if (blockParams.ContainsKey("ischart") &&
                    "true".Equals(blockParams ["ischart"]))
                {
                    block.isChart = true;
                    // parse dataBlock
                    if (blockParams.ContainsKey("datablock"))
                    {
                        block.chartDataBlockName = blockParams["datablock"];

                        // add sheet prefix to tableName
                        if (block.chartDataBlockName.IndexOf('.') < 0)
                        {
                            block.chartDataBlockName = "S" + sheetIndex + "." +
                                                       block.chartDataBlockName;
                        }
                    }
                    else
                    {
                        block.chartDataBlockName = "S" + sheetIndex + ".block2";
                    }
                    // find chartDataBlock
                    for (int i = 0; i < tpl.blockList.Count; i++)
                    {
                        TplBlock blk = tpl.blockList [i];
                        if (blk.name.Equals(block.chartDataBlockName))
                        {
                            block.chartDataBlock = blk;
                        }
                    }



                    if (blockParams.ContainsKey("seriesfrom") &&
                        "col".Equals(blockParams ["seriesfrom"]))
                    {
                        block.chartSeriesFrom = false;
                    }
                }
                int blockRows = block.tplRowCount = int.Parse(blockParams ["rows"]);

                lastValuedRowIndex += blockRows;
                if (blockParams.ContainsKey("copy"))
                {
                    block.copyOnly = "true".Equals(blockParams ["copy"]);
                }


                block.tableName = blockParams ["table"];

                // add sheet prefix to tableName
                if (block.tableName.IndexOf('.') < 0)
                {
                    block.tableName = "S" + sheetIndex + "." + block.tableName;
                }


                if (blockParams.ContainsKey("updateallrow"))
                {
                    block.updateAllRow = "true".Equals(blockParams["updateallrow"]);
                }

                if (blockParams.ContainsKey("autofit") && blockParams["autofit"] == "true")
                {
                    tpl.autoFit = true;
                }

                if (blockParams.ContainsKey("joinat"))
                {
                    if (!int.TryParse(blockParams ["joinat"], out block.joinat))
                    {
                        block.joinat = -1;
                    }
                }

                //if (blockParams.ContainsKey("emptycount"))
                //{
                //    if (!int.TryParse(blockParams["emptycount"], out block.defaultEmptyRowsCount))
                //        block.defaultEmptyRowsCount  = 0;
                //}
                if (blockParams.ContainsKey("emptytable"))
                {
                    block.emptyTableName = blockParams["emptytable"];
                    // add sheet prefix to tableName
                    if (block.emptyTableName.IndexOf('.') < 0)
                    {
                        block.emptyTableName = "S" + sheetIndex + "." + block.emptyTableName;
                    }
                }
                if (blockParams.ContainsKey("coltable"))
                {
                    block.tplColTableName = blockParams["coltable"];
                    // add sheet prefix to tableName
                    if (block.tplColTableName.IndexOf('.') < 0)
                    {
                        block.tplColTableName = "S" + sheetIndex + "." + block.tplColTableName;
                    }
                }

                block.tplRange = RangeHelper.GetRange(sheet, block.startColIndex, block.startRowIndex,
                                                      block.colCount, blockRows);

                if (block.copyOnly)
                // Just return directly.
                {
                    tpl.blockList.Add(block);
                    continue;
                }


                for (int i = 0; i < blockRows; i++)
                {
                    TplLine line = ParseLine(sheet, block, 3, i + block.startRowIndex, block.colCount);
                    line.tpl          = tpl;
                    line.colIndex     = 3;
                    line.iOption      = GetLineInsertOption(RangeHelper.GetCell(sheet, 2, i + block.startRowIndex).Value2 as string);
                    line.tplCellCount = block.colCount;
                    block.lineList.Add(line);
                }

                block.InitDColumn();
                if (block.dColumn != null)
                {
                    block.dColumn.tpl = tpl;
                }

                tpl.blockList.Add(block);
            }

            tpl.startRowIndex = lastValuedRowIndex + 5;
            return(tpl);
        }
        public void FillTemplate()
        {
            for (int i = 0; i < blockList.Count; i++)
            {
                TplBlock block = blockList [i];

                if (block.copyOnly)
                {
                    Range range = RangeHelper.InsertCopyRange(sheet, block.tplRange,
                                                              block.tplColumCount, block.tplRowCount,
                                                              block.startColIndex, startRowIndex + rowCount,
                                                              XlInsertShiftDirection.xlShiftDown);

                    IEnumerator e = RangeHelper.GetRangeCells(range);

                    while (e.MoveNext())
                    {
                        Range cell = (Range)e.Current;

                        if (cell.HasMerged)
                        {
                            continue;
                        }

                        string s = cell.Value2 as string;

                        if (s != null && s.StartsWith("#") && s.Length > 1 &&
                            paramMap != null)
                        {
                            s = s.Substring(1);
                            string[] s2 = s.Split(new char[] { ':' }, StringSplitOptions.RemoveEmptyEntries);


                            object pValue = null;
                            paramMap.TryGetValue(s2 [0], out pValue);
                            string format = "";
                            if (s2.Length > 1)
                            {
                                format = s2 [1].ToLower();
                            }
                            RangeHelper.UpdateCellValue(this, cell, pValue, format);
                        }

                        CellRange origin = RangeHelper.GetRange(sheet, cell.Column, cell.Row - startRowIndex - rowCount + block.startRowIndex, 1, 1);
                        if (origin.HasMerged)
                        {
                            // doMerge
                            int col     = origin.MergeArea.Column;
                            int mWidth  = origin.MergeArea.ColumnCount;
                            int row     = origin.MergeArea.Row + startRowIndex + rowCount - block.startRowIndex;
                            int mHeight = origin.MergeArea.RowCount;

                            CellRange mRange = RangeHelper.GetRange(sheet, col, row, mWidth, mHeight);
                            if (!mRange.HasMerged)
                            {
                                mRange.Merge();
                            }
                        }
                    }

                    rowCount += block.tplRowCount;
                }
                else
                {
                    block.startRowIndex = startRowIndex + rowCount;

                    if (block.isChart)
                    {
                        // chart block should be filled at last.
                        return;
                    }

                    // check cloumn table first
                    if (!string.IsNullOrEmpty(block.tplColTableName) &&
                        dset.Tables.Contains(block.tplColTableName))
                    {
                        block.CreateDColumns(dset.Tables [block.tplColTableName]);
                    }

                    if (!dset.Tables.Contains(block.tableName))
                    {
                        throw new ArgumentException("DataTable [" + block.tableName + "] of Block [" + block.name + "] not found in DataSet!");
                    }


                    if (dset.Tables[block.tableName].Rows.Count <= 0 && block.emptyTableName != null)
                    {
                        rowCount += block.FillBlock(dset.Tables[block.emptyTableName]);
                    }
                    else
                    {
                        rowCount += block.FillBlock(dset.Tables [block.tableName]);
                    }
                }
            }
        }