本文整理汇总了C#中Mapper.ParseAll方法的典型用法代码示例。如果您正苦于以下问题:C# Mapper.ParseAll方法的具体用法?C# Mapper.ParseAll怎么用?C# Mapper.ParseAll使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Mapper
的用法示例。
在下文中一共展示了Mapper.ParseAll方法的13个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: ParseSecuritiesInfo
private static void ParseSecuritiesInfo(XContainer xml, IDBContext context)
{
var instrumentMapper = new Mapper<Instrument>(xml.Descendants("SecurityInfo"));
List<Instrument> instruments = instrumentMapper.ParseAll();
foreach (Instrument i in instruments)
{
if (context.Instruments.Count(x => x.ConID == i.ConID) == 0)
{
context.Instruments.Add(i);
context.SaveChanges();
}
}
//<SecurityInfo @assetCategoryassetCategory="STK" symbol="AAPL" description="APPLE INC"
//conid="265598" securityID="" securityIDType="" cusip="" isin="" underlyingConid=""
//underlyingSymbol="" issuer="" multiplier="1" expiry="" strike="" maturity="-" issueDate="" />
}
示例2: ParseAllReturnsAllElementsCorrectly
public void ParseAllReturnsAllElementsCorrectly()
{
string input = "<Collection>" +
"<TestClass IntProp=\"0\" /> " +
"<TestClass IntProp=\"1\" /> " +
"<TestClass IntProp=\"2\" /> " +
"<TestClass IntProp=\"3\" /> " +
"<TestClass IntProp=\"4\" /> " +
"<TestClass IntProp=\"5\" /> " +
"</Collection>";
var mapper = new Mapper<TestClass>(input);
List<TestClass> result = mapper.ParseAll();
Assert.AreEqual(6, result.Count);
for (int i = 0; i < 6; i++)
{
Assert.AreEqual(i, result[i].IntProp);
}
}
示例3: ParseCFDCharges
private static void ParseCFDCharges(XContainer xml, IDBContext context, bool skipLastDateCheck, DateTime lastDate, Account account)
{
var cfdTransactionsMapper = new Mapper<CashTransaction>(xml.Descendants("CFDCharge"));
cfdTransactionsMapper.SetAttributeMap("total", "Amount");
cfdTransactionsMapper.SetAttributeMap("date", "TransactionDate", "yyyy-MM-dd");
List<CashTransaction> cfdCharges = cfdTransactionsMapper.ParseAll();
var instruments = context.Instruments.ToList();
var currencies = context.Currencies.ToList();
foreach (CashTransaction i in cfdCharges)
{
i.Type = "CFD Charge";
if (skipLastDateCheck || i.TransactionDate > lastDate)
{
i.Account = account;
i.Currency = currencies.FirstOrDefault(x => x.Name == i.CurrencyString);
i.Instrument = instruments.FirstOrDefault(x => x.ConID == i.ConID);
context.CashTransactions.Add(i);
}
}
context.SaveChanges();
//<CFDCharge accountId="U1066712F" currency="USD" assetCategory="CFD" fxRateToBase="1"
//symbol="--" description="--" conid="--" securityID="--" securityIDType="--" cusip="--"
//isin="--" underlyingConid="--" underlyingSymbol="--" issuer="--" date="2013-01-03" received="0"
//paid="-1.27" total="-1.27" transactionID="3283049378" />
}
示例4: ParseCashTransactions
private static void ParseCashTransactions(XContainer xml, IDBContext context, bool skipLastDateCheck, DateTime lastDate, Account account)
{
var cashTransactionsMapper = new Mapper<CashTransaction>(xml.Descendants("CashTransaction"));
List<CashTransaction> cashTransactions = cashTransactionsMapper.ParseAll();
var instruments = context.Instruments.ToList();
var currencies = context.Currencies.ToList();
foreach (CashTransaction i in cashTransactions)
{
if (skipLastDateCheck || i.TransactionDate > lastDate)
{
i.Account = account;
i.Currency = currencies.FirstOrDefault(x => x.Name == i.CurrencyString);
i.Instrument = instruments.FirstOrDefault(x => x.ConID == i.ConID);
context.CashTransactions.Add(i);
}
}
context.SaveChanges();
//<CashTransaction accountId="U1066712" currency="CAD" assetCategory="STK" fxRateToBase="0.99717"
//symbol="XRE" description="XRE() DIVIDEND .0615 CAD PER SHARE - CA TAX" conid="74580643" securityID=""
//securityIDType="" cusip="" isin="" underlyingConid="" underlyingSymbol="" issuer="" dateTime="2012-07-31"
//amount="-6.92" type="Withholding Tax" tradeID="" code="" />
}
示例5: ParseExecutions
private static void ParseExecutions(XContainer xml, IDBContext context, bool skipLastDateCheck, Account account)
{
if (!xml.Descendants("Trades").Any()) return;
var tradesMapper = new Mapper<Execution>(xml.Descendants("Trades").First().Descendants("Trade"));
List<Execution> executions = tradesMapper.ParseAll();
DateTime lastDate = context.Executions.Any(x => x.AccountID == account.ID)
? context.Executions.Where(x => x.AccountID == account.ID).Max(x => x.TradeDate)
: new DateTime(1, 1, 1);
var currencies = context.Currencies.ToList();
var instruments = context.Instruments.ToList();
var orderReferenceSet = new List<long>(); //used to keep track of which orders we have set the order reference for, so we don't do it multiple times
//then add the new ones
foreach (Execution i in executions)
{
if (i.TradeDate > lastDate || skipLastDateCheck)
{
i.Account = account;
i.Instrument = instruments.FirstOrDefault(x => x.ConID == i.ConID);
i.Currency = currencies.FirstOrDefault(x => x.Name == i.CurrencyString);
i.CommissionCurrency = currencies.FirstOrDefault(x => x.Name == i.CommissionCurrencyString);
var order = context.Orders.FirstOrDefault(x => x.IBOrderID == i.IBOrderID);
i.Order = order;
if (!string.IsNullOrEmpty(i.OrderReference) && !orderReferenceSet.Contains(i.IBOrderID))
{
orderReferenceSet.Add(i.IBOrderID);
order.OrderReference = i.OrderReference;
((IObjectContextAdapter)context).ObjectContext.ObjectStateManager.ChangeObjectState(order, EntityState.Modified);
}
context.Executions.Add(i);
}
}
context.SaveChanges();
//<Trade accountId="U1066712" currency="USD" assetCategory="STK" fxRateToBase="1" symbol="VGK"
//description="VANGUARD MSCI EUROPEAN ETF" conid="27684070" securityID="" securityIDType="" cusip="" isin=""
//underlyingConid="" underlyingSymbol="" issuer="" tradeID="812956946" reportDate="20121231" tradeDate="20121231"
//tradeTime="160000" settleDateTarget="20130104" transactionType="ExchTrade" exchange="ARCA" quantity="-60" tradePrice="48.84"
//multiplier="1" tradeMoney="-2930.4" proceeds="2930.4" taxes="0" ibCommission="-1" ibCommissionCurrency="USD" closePrice="48.84"
//openCloseIndicator="C" notes="P;" cost="-2869.2" fifoPnlRealized="60.2" mtmPnl="0" origTradePrice="0" origTradeDate=""
//origTradeID="" origOrderID="0" strike="" expiry="" putCall="" buySell="SELL" ibOrderID="415554439"
//ibExecID="0000d3de.50e1a59d.01.01" brokerageOrderID="" orderReference="" volatilityOrderLink=""
//orderPlacementTime="" clearingFirmID="" exchOrderId="N/A" extExecID="AD_5629512420665350" orderTime="20121231;142412"
//openDateTime="--" holdingPeriodDateTime="--" whenRealized="--" whenReopened="--" levelOfDetail="EXECUTION"
//changeInPrice="0" changeInQuantity="0" netCash="2929.4" orderType="MOC" />
}
示例6: ParseOrders
private static void ParseOrders(XContainer xml, IDBContext context, bool skipLastDateCheck, Account account)
{
if (!xml.Descendants("Trades").Any()) return;
var ordersMapper = new Mapper<Order>(xml.Descendants("Trades").First().Descendants("Order"));
List<Order> orders = ordersMapper.ParseAll();
DateTime lastDate = context.Orders.Any(x => x.AccountID == account.ID)
? context.Orders.Where(x => x.AccountID == account.ID).Max(x => x.TradeDate)
: new DateTime(1, 1, 1);
var instruments = context.Instruments.ToList();
var currencies = context.Currencies.ToList();
//then add the new ones
foreach (Order order in orders)
{
if (order.TradeDate > lastDate || skipLastDateCheck)
{
order.IsReal = true;
if(order.AssetCategory == AssetClass.Cash)
{
//These are currency trades. But currencies aren't provided in the SecuritiesInfos
//So we have to hack around it and add the currency as an instrument "manually" if it's not in yet
order.Instrument = TryAddAndGetCurrencyInstrument(order, context);
}
else
{
order.Instrument = instruments.FirstOrDefault(x => x.ConID == order.ConID);
}
order.Account = account;
order.Currency = currencies.FirstOrDefault(x => x.Name == order.CurrencyString);
order.CommissionCurrency = currencies.FirstOrDefault(x => x.Name == order.CommissionCurrencyString);
context.Orders.Add(order);
}
}
context.SaveChanges();
//<Order accountId="U1066712" currency="USD" assetCategory="STK" fxRateToBase="1" symbol="AAPL"
//description="APPLE INC" conid="265598" securityID="" securityIDType="" cusip="" isin=""
//underlyingConid="" underlyingSymbol="" issuer="" tradeID="--" reportDate="20140325" tradeDate="20140325"
//tradeTime="093002" settleDateTarget="20140328" transactionType="--" exchange="--" quantity="-48"
//tradePrice="541.37" multiplier="1" tradeMoney="-25985.76" proceeds="25985.76" taxes="0" ibCommission="-1.574285"
//ibCommissionCurrency="USD" closePrice="544.99" openCloseIndicator="C" notes="C" cost="-25877.8" fifoPnlRealized="106.385715"
//mtmPnl="-173.76" origTradePrice="--" origTradeDate="--" origTradeID="--" origOrderID="--" strike="" expiry="" putCall=""
//buySell="SELL" ibOrderID="537171278" ibExecID="--" brokerageOrderID="--" orderReference="--" volatilityOrderLink="--"
//orderPlacementTime="--" clearingFirmID="--" exchOrderId="--" extExecID="--" orderTime="20140325;093002" openDateTime="--"
//holdingPeriodDateTime="--" whenRealized="--" whenReopened="--" levelOfDetail="ORDER" changeInPrice="--" changeInQuantity="--"
//netCash="25984.185715" orderType="LMT" />
}
示例7: ParseOpenPositions
private static void ParseOpenPositions(XContainer xml, IDBContext context, Account account)
{
if (!xml.Descendants("OpenPositions").Any()) return;
var openPositionsMapper = new Mapper<OpenPosition>(xml.Descendants("OpenPosition").Where(x => x.Attribute("levelOfDetail").Value == "SUMMARY"));
List<OpenPosition> openPositions = openPositionsMapper.ParseAll();
//start by deleting the old ones
context.OpenPositions.RemoveRange(context.OpenPositions.Where(x => x.AccountID == account.ID).ToList());
context.SaveChanges();
//then add the new ones
foreach (OpenPosition i in openPositions)
{
i.Account = account;
i.Instrument = context.Instruments.FirstOrDefault(x => x.ConID == i.ConID);
i.Currency = context.Currencies.FirstOrDefault(x => x.Name == i.CurrencyString);
context.OpenPositions.Add(i);
}
context.SaveChanges();
//<OpenPosition accountId="U1066712" currency="USD" assetCategory="STK" fxRateToBase="1" symbol="ACWV"
//description="ISHARES MSCI ALL COUNTRY WOR" conid="96090060" securityID="" securityIDType="" cusip=""
//isin="" underlyingConid="" underlyingSymbol="" issuer="" reportDate="20130131" position="18" multiplier="1"
//markPrice="58.01" positionValue="1044.18" openPrice="55.877777778" costBasisPrice="55.877777778"
//costBasisMoney="1005.8" percentOfNAV="1.61" fifoPnlUnrealized="38.38" side="Long" @levelOfDetaillevelOfDetail="SUMMARY"
//openDateTime="" holdingPeriodDateTime="" code="" originatingOrderID="" />
}
示例8: ParseEquitySummaries
private static void ParseEquitySummaries(XContainer xml, IDBContext context, Account account)
{
var equitySummaryMapper = new Mapper<EquitySummary>(xml.Descendants("EquitySummaryByReportDateInBase"));
List<EquitySummary> equitySummaries = equitySummaryMapper.ParseAll();
foreach (EquitySummary i in equitySummaries)
{
if (context.EquitySummaries.Count(x => x.Date == i.Date && x.AccountID == account.ID) == 0)
{
i.Account = account;
context.EquitySummaries.Add(i);
context.SaveChanges();
}
}
//<EquitySummaryByReportDateInBase accountId="U1066712" reportDate="2012-07-18" cash="-8839.601715" cashLong="0"
//cashShort="-8839.601715" slbCashCollateral="0" slbCashCollateralLong="0" slbCashCollateralShort="0"
//stock="38134.228955" stockLong="38134.228955" stockShort="0" slbDirectSecuritiesBorrowed="0"
//slbDirectSecuritiesBorrowedLong="0" slbDirectSecuritiesBorrowedShort="0" slbDirectSecuritiesLent="0"
//slbDirectSecuritiesLentLong="0" slbDirectSecuritiesLentShort="0" options="235.75" optionsLong="235.75"
//optionsShort="0" commodities="0" commoditiesLong="0" commoditiesShort="0" bonds="0" bondsLong="0" bondsShort="0"
//notes="0" notesLong="0" notesShort="0" interestAccruals="-7.2318305" interestAccrualsLong="0"
//interestAccrualsShort="-7.2318305" softDollars="0" softDollarsLong="0" softDollarsShort="0" dividendAccruals="0"
//dividendAccrualsLong="0" dividendAccrualsShort="0" total="29523.1454095" totalLong="38369.978955" totalShort="-8846.8335455" />
}
示例9: ParseFXRates
private static void ParseFXRates(XContainer xml, IDBContext context)
{
var fxRatesMapper = new Mapper<FXRate>(xml.Descendants("ConversionRate"));
List<FXRate> fxRates = fxRatesMapper.ParseAll();
var currencies = context.Currencies.ToList();
foreach (FXRate i in fxRates)
{
i.FromCurrency = currencies.FirstOrDefault(x => x.Name == i.FromCurrencyString);
i.ToCurrency = currencies.FirstOrDefault(x => x.Name == i.ToCurrencyString);
if (!context.FXRates.Any(x =>
x.FromCurrency.ID == i.FromCurrency.ID &&
x.ToCurrency.ID == i.ToCurrency.ID &&
x.Date == i.Date))
{
context.FXRates.Add(i);
}
}
context.SaveChanges();
//<ConversionRate reportDate="2012-12-28" fromCurrency="CHF" toCurrency="USD" rate="1.0947" />
}
示例10: ParsePriorPeriodPositions
private static void ParsePriorPeriodPositions(XContainer xml, IDBContext context, bool skipLastDateCheck, Account account)
{
var priorPeriodPositionsMapper = new Mapper<PriorPosition>(xml.Descendants("PriorPeriodPosition"));
List<PriorPosition> priorPeriodPositions = priorPeriodPositionsMapper.ParseAll();
DateTime lastDate = context.PriorPositions.Any(x => x.AccountID == account.ID)
? context.PriorPositions.Where(x => x.AccountID == account.ID).Max(x => x.Date)
: new DateTime(1, 1, 1);
var currencies = context.Currencies.ToList();
var instruments = context.Instruments.ToList();
foreach (PriorPosition i in priorPeriodPositions)
{
if (skipLastDateCheck || i.Date > lastDate)
{
i.Account = account;
i.Currency = currencies.FirstOrDefault(x => x.Name == i.CurrencyString);
i.Instrument = instruments.FirstOrDefault(x => x.ConID == i.ConID);
context.PriorPositions.Add(i);
}
}
context.SaveChanges();
//<PriorPeriodPosition accountId="U1066712" currency="USD" assetCategory="STK" fxRateToBase="1" symbol="ACWV"
//description="ISHARES MSCI ALL COUNTRY WOR" conid="96090060" securityID="" securityIDType="" cusip="" isin=""
//underlyingConid="" underlyingSymbol="" issuer="" date="2012-12-28" price="55.23" priorMtmPnl="-9" />
}
示例11: ParseOpenDividendAccruals
private static void ParseOpenDividendAccruals(XContainer xml, IDBContext context, Account account)
{
var openDividendAccrualsMapper = new Mapper<DividendAccrual>(xml.Descendants("OpenDividendAccrual"));
List<DividendAccrual> dividendAccruals = openDividendAccrualsMapper.ParseAll();
//delete all of them
context.DividendAccruals.RemoveRange(context.DividendAccruals.Where(x => x.AccountID == account.ID).ToList());
//then add the new ones
foreach (DividendAccrual i in dividendAccruals)
{
i.Currency = context.Currencies.FirstOrDefault(x => x.Name == i.CurrencyString);
i.Instrument = context.Instruments.FirstOrDefault(x => x.ConID == i.ConID);
i.Account = account;
if (i.Instrument == null)
{
var logger = LogManager.GetCurrentClassLogger();
logger.Log(LogLevel.Error, "Could not find instrument for dividend accrual with conid: " + i.ConID);
}
else
{
context.DividendAccruals.Add(i);
}
}
context.SaveChanges();
//<OpenDividendAccrual accountId="U1066712" currency="USD" assetCategory="STK" fxRateToBase="1" symbol="PICB"
//description="POWERSHARES INT CORP BOND" conid="75980548" securityID="" securityIDType="" cusip="" isin=""
//underlyingConid="" underlyingSymbol="" issuer="" exDate="2013-01-15" payDate="2013-01-31" quantity="19" tax="0.44"
//fee="0" grossRate="0.07613" grossAmount="1.45" netAmount="1.01" code="" fromAcct="" toAcct="" />
}
示例12: ParseFXPositions
private static void ParseFXPositions(XContainer xml, IDBContext context, Account account)
{
var fxPositionsMapper = new Mapper<FXPosition>(xml.Descendants("FxPosition"));
List<FXPosition> fxPositions = fxPositionsMapper.ParseAll();
//delete all of them
context.FXPositions.RemoveRange(context.FXPositions.Where(x => x.AccountID == account.ID).ToList());
//then add the new ones
foreach (FXPosition i in fxPositions)
{
i.FunctionalCurrency = context.Currencies.FirstOrDefault(x => x.Name == i.FunctionalCurrencyString);
i.FXCurrency = context.Currencies.FirstOrDefault(x => x.Name == i.FXCurrencyString);
i.Account = account;
context.FXPositions.Add(i);
}
context.SaveChanges();
//<FxPosition accountId="U1066712" acctAlias="" assetCategory="CASH" reportDate="20140325"
//functionalCurrency="USD" fxCurrency="CAD" quantity="22.379966" costPrice="0.890970031" costBasis="-19.939879"
//closePrice="0.89552" value="20.041707" unrealizedPL="0.101828" code="" lotDescription="" lotOpenDateTime="" levelOfDetail="SUMMARY" />
}
示例13: ParseFXTransactions
private static void ParseFXTransactions(XContainer xml, IDBContext context, bool skipLastDateCheck, Account account)
{
var fxTransactionMapper = new Mapper<FXTransaction>(xml.Descendants("FxTransaction"));
List<FXTransaction> fxTransactions = fxTransactionMapper.ParseAll();
DateTime lastDate = context.FXTransactions.Any(x => x.AccountID == account.ID)
? context.FXTransactions.Where(x => x.AccountID == account.ID).Max(x => x.DateTime)
: new DateTime(1, 1, 1);
var currencies = context.Currencies.ToList();
//then add the new ones
foreach (FXTransaction i in fxTransactions)
{
if (i.DateTime > lastDate || skipLastDateCheck)
{
i.FunctionalCurrency = currencies.FirstOrDefault(x => x.Name == i.FunctionalCurrencyString);
i.FXCurrency = currencies.FirstOrDefault(x => x.Name == i.FXCurrencyString);
context.FXTransactions.Add(i);
}
}
context.SaveChanges();
//<FxTransaction accountId="U1066712" acctAlias="" assetCategory="CASH" reportDate="20130401"
//functionalCurrency="USD" fxCurrency="CAD" activityDescription="XRE() DIVIDEND .06726 CAD PER SHARE"
//dateTime="20130328;202000" quantity="16.29" proceeds="16.034084" cost="-16.034084" realizedPL="0"
//code="O" levelOfDetail="TRANSACTION" />
}