2016-10-26 6 views
2

저는 angularJS에서 새롭고 파일을 엑셀 파일로 내보내고 싶습니다. 각 셀에 각 값이 있습니다. 것이 가능하다? 방법? 어떤예요?AngularJS : ui-grid 데이터를 내보내는 방법 Excel

미리 감사드립니다.

+0

당신은이 링크를 시도 할 수 있습니다 Excel 용, 쉽게 CSV로 내보낼 수 있습니다 http://jordiburgos.com/post/2013/javascript-export-to-excel.html –

+0

CSV Excel에서 열립니다,이 참조 링크 : http://plnkr.co/edit/btiJb94V1GcMGQueAwPd?p=preview –

+0

@ Dan : 해결책이 있습니까? – techprat

답변

1

나는이 사용 js-xlsx achive 및 FileSaver

http://plnkr.co/edit/DVhIUgGD04yDXtjp7ReW

이 코드 블록은 수출 서비스입니다 수 있습니다.

(function() { 
    'use strict'; 

    angular 
     .module('app.utils') 
     .factory('exportUiGridService', exportUiGridService); 

    /* @ngInject */ 
    function exportUiGridService(uiGridExporterService) { 
     var service = { 
      exportToExcel: exportToExcel 
     }; 

     return service; 

     function Workbook() { 
      if (!(this instanceof Workbook)) return new Workbook(); 
      this.SheetNames = []; 
      this.Sheets = {}; 
     } 

     function exportToExcel(sheetName, gridApi, rowTypes, colTypes) { 
      var columns = gridApi.grid.options.showHeader ? uiGridExporterService.getColumnHeaders(gridApi.grid, colTypes) : []; 
      var data = uiGridExporterService.getData(gridApi.grid, rowTypes, colTypes); 
      var fileName = gridApi.grid.options.exporterExcelFilename ? gridApi.grid.options.exporterExcelFilename : 'dokuman'; 
      fileName += '.xlsx'; 
      var wb = new Workbook(), 
       ws = sheetFromArrayUiGrid(data, columns); 
      wb.SheetNames.push(sheetName); 
      wb.Sheets[sheetName] = ws; 
      var wbout = XLSX.write(wb, { 
       bookType: 'xlsx', 
       bookSST: true, 
       type: 'binary' 
      }); 
      saveAs(new Blob([s2ab(wbout)], { 
       type: 'application/octet-stream' 
      }), fileName); 
     } 

     function sheetFromArrayUiGrid(data, columns) { 
      var ws = {}; 
      var range = { 
       s: { 
        c: 10000000, 
        r: 10000000 
       }, 
       e: { 
        c: 0, 
        r: 0 
       } 
      }; 
      var C = 0; 
      columns.forEach(function (c) { 
       var v = c.displayName || c.name; 
       addCell(range, v, 0, C, ws); 
       C++; 
      }, this); 
      var R = 1; 
      data.forEach(function (ds) { 
       C = 0; 
       ds.forEach(function (d) { 
        var v = d.value; 
        addCell(range, v, R, C, ws); 
        C++; 
       }); 
       R++; 
      }, this); 
      if (range.s.c < 10000000) ws['!ref'] = XLSX.utils.encode_range(range); 
      return ws; 
     } 

     function datenum(v, date1904) { 
      if (date1904) v += 1462; 
      var epoch = Date.parse(v); 
      return (epoch - new Date(Date.UTC(1899, 11, 30)))/(24 * 60 * 60 * 1000); 
     } 

     function s2ab(s) { 
      var buf = new ArrayBuffer(s.length); 
      var view = new Uint8Array(buf); 
      for (var i = 0; i != s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF; 
      return buf; 
     } 

     function addCell(range, value, row, col, ws) { 
      if (range.s.r > row) range.s.r = row; 
      if (range.s.c > col) range.s.c = col; 
      if (range.e.r < row) range.e.r = row; 
      if (range.e.c < col) range.e.c = col; 
      var cell = { 
       v: value 
      }; 
      if (cell.v == null) cell.v = '-'; 
      var cell_ref = XLSX.utils.encode_cell({ 
       c: col, 
       r: row 
      }); 

      if (typeof cell.v === 'number') cell.t = 'n'; 
      else if (typeof cell.v === 'boolean') cell.t = 'b'; 
      else if (cell.v instanceof Date) { 
       cell.t = 'n'; 
       cell.z = XLSX.SSF._table[14]; 
       cell.v = datenum(cell.v); 
      } else cell.t = 's'; 

      ws[cell_ref] = cell; 
     } 
    } 
})(); 

이것은 그리드 메뉴의 작업에 대한 옵션입니다.

ctrl.gridOptions = { 
       appScopeProvider: ctrl, 
       enableFiltering: true, 
       enableColumnResizing: true, 
       enableGridMenu: true, 
       showGridFooter: true, 
       showColumnFooter: true, 
       exporterMenuCsv: false, 
       columnDefs: [ 
        . 
        . 
        . 
       ], 
       onRegisterApi: function (gridApi) { 
        ctrl.gridApi = gridApi; 
       }, 
       gridMenuCustomItems: [{ 
         title: 'Export all data as EXCEL', 
         action: function ($event) { 
          exportUiGridService.exportToExcel('Sheet 1', ctrl.gridApi, 'all', 'all'); 
         }, 
         order: 110 
        }, 
        { 
         title: 'Export visible data as EXCEL', 
         action: function ($event) { 
          exportUiGridService.exportToExcel('Sheet 1', ctrl.gridApi, 'visible', 'visible'); 
         }, 
         order: 111 
        } 
       ] 
      }; 
+0

내 보낸 Excel에 특정 템플릿을 설정하려면 어떻게해야합니까? –