本文整理汇总了C#中Workbook.PivotCaches方法的典型用法代码示例。如果您正苦于以下问题:C# Workbook.PivotCaches方法的具体用法?C# Workbook.PivotCaches怎么用?C# Workbook.PivotCaches使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Workbook
的用法示例。
在下文中一共展示了Workbook.PivotCaches方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: GetPowerPivotConnection
//((dynamic)pc.WorkbookConnection).ModelConnection.ADOConnection.ConnectionString
// Excel 2013
//"Provider=MSOLAP.5;Persist Security Info=True;Initial Catalog=Microsoft_SQLServer_AnalysisServices;Data Source=$Embedded$;MDX Compatibility=1;Safety Options=2;MDX Missing Member Mode=Error;Subqueries=0;Optimize Response=7"
// Excel 2010
// Provider=MSOLAP.5;Persist Security Info=True;Initial Catalog=Microsoft_SQLServer_AnalysisServices;Data Source=$Embedded$;MDX Compatibility=1;Safety Options=2;MDX Missing Member Mode=Error;ConnectTo=11.0;Optimize Response=3;Cell Error Mode=TextValue;location=\"C:\Users\Test\Documents\Products.xlsx\";Show Hidden Cubes=true"
/*
public ADOTabularConnection GetPowerPivotConnection()
{
PivotCache pc;
string connStr;
var wb = _app.ActiveWorkbook;
if (IsExcel2013OrLater)
{
PivotCaches pvtcaches = wb.PivotCaches();
pc = (from PivotCache pvtc in pvtcaches
let conn = pvtc.Connection.ToString()
where pvtc.OLAP
&& pvtc.CommandType == XlCmdType.xlCmdCube
&& (int) pvtc.WorkbookConnection.Type == 7 // xl15Model
select pvtc).First();
var wbc = ((dynamic)pc.WorkbookConnection);
var modelCnn = wbc.ModelConnection;
//var wbkCnn = FindPowerPivotConnection(wb);
//var modelCnn = wbkCnn.ModelConnection;
var cnn = modelCnn.ADOConnection;
connStr = cnn.ConnectionString;
connStr = string.Format("{0};location=\"{1}\"", connStr, wb.FullName);
// for connections to Excel 2013 or later we need to use the Excel version of ADOMDClient
return new ADOTabularConnection(connStr, AdomdType.Excel);
}
else
{
// Excel 2010
PivotCaches pvtcaches = wb.PivotCaches();
pc = (from PivotCache pvtc in pvtcaches
let conn = pvtc.Connection.ToString()
where pvtc.OLAP
&& pvtc.CommandType == XlCmdType.xlCmdCube
//&& (int)pvtc.WorkbookConnection.Type == 7
select pvtc).First();
if (pc == null) pc = CreateHiddenPivotTable(wb);
var wbc = ((dynamic) pc.WorkbookConnection);
var oledbCnn = wbc.OLEDBConnection;
var cnn = oledbCnn.Connection;
connStr = cnn.Replace("OLEDB;","");
connStr = string.Format("{0};location=\"{1}\"", connStr, wb.FullName);
// for connections to Excel 2010 we need to use the AnalysisServices version of ADOMDClient
return new ADOTabularConnection(connStr, AdomdType.AnalysisServices);
}
}
*/
private PivotCache CreateHiddenPivotTable(Workbook wb)
{
Worksheet sht = null;
try
{
sht = wb.Sheets["DaxStudioConnectionHelper"];
}
catch { } // swallow any exception if the sheet is not found
if (sht == null) {
sht = wb.Sheets.Add();
sht.Name = "DaxStudioConnectionHelper";
sht.Visible = XlSheetVisibility.xlSheetVeryHidden;
}
//PivotTable pt;
PivotCaches pivotCaches;
pivotCaches = wb.PivotCaches();
var pc = pivotCaches.Create(XlPivotTableSourceType.xlExternal, wb.Connections["PowerPivot Data"], XlPivotTableVersionList.xlPivotTableVersion14);
pc.CreatePivotTable(sht.Cells[1,1], "DaxStudioConnectionPivot", Type.Missing, XlPivotTableVersionList.xlPivotTableVersion14);
return pc;
//pc = wb.PivotCaches.Create( SourceType= xlExternal, SourceData:= wb.Connections["PowerPivot Data"], Version:=xlPivotTableVersion14)
//pt = pc.CreatePivotTable(TableDestination:="DaxStudioConnectionHelper!R1C1", TableName:= "DaxStudioConnectionPivotTable", DefaultVersion:=xlPivotTableVersion14);
}