本文整理匯總了C#中AST.GroupBy方法的典型用法代碼示例。如果您正苦於以下問題:C# AST.GroupBy方法的具體用法?C# AST.GroupBy怎麽用?C# AST.GroupBy使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類AST
的用法示例。
在下文中一共展示了AST.GroupBy方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: StoreOutputs
public static Dictionary<AST.Address, string> StoreOutputs(AST.Address[] outputs, DAG dag)
{
// output dict
var d = new Dictionary<AST.Address, string>();
// partition all of the output addresses by their worksheet
var addr_groups = outputs.GroupBy(addr => dag.getCOMRefForAddress(addr).WorksheetName);
// for each worksheet, do an array read of the formulas
foreach (IEnumerable<AST.Address> ws_fns in addr_groups)
{
// get worksheet used range
var fstcr = dag.getCOMRefForAddress(ws_fns.First());
var rng = fstcr.Worksheet.UsedRange;
// get used range dimensions
var left = rng.Column;
var right = rng.Columns.Count + left - 1;
var top = rng.Row;
var bottom = rng.Rows.Count + top - 1;
// get names
var wsname = new FSharpOption<string>(fstcr.WorksheetName);
var wbname = new FSharpOption<string>(fstcr.WorkbookName);
var path = fstcr.Path;
// sometimes the used range is a range
if (left != right || top != bottom)
{
// y is the first index
// x is the second index
object[,] data = rng.Value2; // fast array read
var x_del = left - 1;
var y_del = top - 1;
foreach (AST.Address addr in ws_fns)
{
// construct address in formulas array
var x = addr.X - x_del;
var y = addr.Y - y_del;
// get string
String s = System.Convert.ToString(data[y, x]);
if (String.IsNullOrWhiteSpace(s))
{
d.Add(addr, "");
}
else
{
d.Add(addr, s);
}
}
}
// and other times it is a single cell
else
{
// construct the appropriate AST.Address
AST.Address addr = AST.Address.NewFromR1C1(top, left, wsname, wbname, path);
// make certain that it is actually a string
String s = System.Convert.ToString(rng.Value2);
// add to dictionary, as appropriate
if (String.IsNullOrWhiteSpace(s))
{
d.Add(addr, "");
}
else
{
d.Add(addr, s);
}
}
}
return d;
}