[ad_1]
I want to pull all the items in the drop-down menu one by one into the datagridview rows using Selenium in C#. Can you help me on this issue?
मैंने क्या प्रयास किया है:
मैंने निम्नलिखित कोड आज़माए।
I tried the code below, but these codes pull all elements into one line. <pre lang="C#"> List<IWebElement> selectElements = drv.FindElements(By.Id("dersler")); foreach (IWebElement select in selectElements) { var selectElement = new SelectElement(select); List<string> lst = new List<string>(); lst.Add(select.Text); DataTable dt = new DataTable(); DataColumn dtcol = new DataColumn(select.Text); dt.Columns.Add(dtcol); for (int i = 0; i < lst.Count; i++) { dataGridView1.DataSource = dt; } }
समाधान 1
आपके कोड स्निपेट के अनुसार, कुछ समस्याएं हैं जो अप्रत्याशित व्यवहार का कारण बन सकती हैं। आप एक बना रहे हैं DataTable
लूप के भीतर, जिससे यह प्रत्येक पुनरावृत्ति के साथ रीसेट हो जाता है। इसे संबोधित करने के लिए, इसे स्थानांतरित करें DataTable
लूप के बाहर निर्माण करें और सेट करें DataTable
के रूप में DataSource
लूप के बाद. नीचे आपके कोड का अद्यतन संस्करण है:
सी#
List<IWebElement> selectElements = drv.FindElements(By.Id("dersler")); // Create DataTable outside the loop to avoid resetting it in each iteration DataTable dt = new DataTable(); foreach (IWebElement select in selectElements) { var selectElement = new SelectElement(select); // Create a new column for each dropdown DataColumn dtcol = new DataColumn(selectElement.Text); dt.Columns.Add(dtcol); // Create a new row for each option in the dropdown foreach (IWebElement option in selectElement.Options) { DataRow row = dt.NewRow(); row[selectElement.Text] = option.Text; dt.Rows.Add(row); } } // Set the DataTable as the DataSource after the loop dataGridView1.DataSource = dt;
[ad_2]
コメント