3

以下のコードは期待どおりに動作していますが、下のコードを変換して Linq を使用したいと考えていますか? 助言がありますか?

       string[] selections = "Men,Women,Boys".Split(',');           

        int _chkboxId = 0;  
        int _chkboxTextId = 1;
        try
        {
            string id = "lstchk_" + _chkboxId;
            while (!driver.FindElement(By.Id(id)).Equals(null))
            {
                string checkboxId = String.Format("lstchk{0}", _chkboxTextId);
                string checkboxName = driver.FindElement(By.Id(checkboxId)).Text;

                foreach (string match in selections)
                {
                    if (checkboxName == match.Trim())
                    {
                        //matched... do more work here...
                    }
                }
           }
4

4 に答える 4

5
foreach (string match in selections.Where(match => checkboxName == match.Trim()))
{
    //matched... do more work here...
}
于 2012-09-25T02:08:38.643 に答える
1
switch(checkboxName) {
    case "Men":
    case "Women":
    case "Boys":
        // do more work here
    default:
        // no match, bail
}

コードの書き方が違うだけの場合もあります。

于 2012-09-25T02:08:40.550 に答える
1

selectionsリストに個別の値のみが含まれている場合、使用できるよりも

if(selections.Any(match=>match.Trim().Equals(checkboxName)))
{
    //Do work
}

あなたのループの代わりに。リストに個別の値が含まれていない場合も同様ですが、作業はそれぞれに対して 1 回だけ行う必要があります。checkboxName

于 2012-09-25T02:28:32.310 に答える
0

この単純な foreach を linq ステートメントにどのように変換しますか?

    public List<string> GetItems()
        {
        var items = new List<string>();

        foreach (Ranorex.ListItem item in ranorexComboBox.Items)
            {
            items.Add(item.Text);
            }

        return items;
        }
于 2013-10-23T12:21:21.150 に答える