1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657 |
- using System;
- using System.Collections.Generic;
- using System.Collections.ObjectModel;
- using System.Data;
- using System.Diagnostics;
- using System.Dynamic;
- using System.IO;
- using System.Linq;
- using System.Threading;
- using System.Xml.Linq;
- using NPOI.HPSF;
- using NPOI.SS.Formula.Functions;
- using OpenQA.Selenium;
- using OpenQA.Selenium.Chrome;
- using OpenQA.Selenium.Interactions;
- using OpenQA.Selenium.Support.Extensions;
- using OpenQA.Selenium.Support.UI;
- namespace wispro.sp.utility
- {
- public class IPEasyUtility
- {
- static string strFileSavePath = ConfigHelper.GetSectionValue("IPEasySetting:DownloadFileSavePath");
- static string Account = ConfigHelper.GetSectionValue("IPEasySetting:Account");
- static string Password = ConfigHelper.GetSectionValue("IPEasySetting:Password");
- static bool WaitForFileDownload(string downloadDir, string fileName, TimeSpan timeout)
- {
- DateTime startTime = DateTime.Now;
- while (DateTime.Now - startTime < timeout)
- {
- string filePath = Path.Combine(downloadDir, fileName);
- if (File.Exists(filePath))
- {
- // 检查文件是否完成写入(文件大小是否稳定)
- long previousSize = 0;
- long currentSize = new FileInfo(filePath).Length;
- while (previousSize != currentSize)
- {
- Thread.Sleep(1000); // 等待一段时间
- previousSize = currentSize;
- currentSize = new FileInfo(filePath).Length;
- }
- return true; // 文件下载完成
- }
- Thread.Sleep(1000); // 等待文件出现
- }
- return false; // 超时,文件未下载完成
- }
- static IWebElement waitGetElementById(WebDriverWait wait,string id,IWebElement parentElement =null)
- {
- return wait.Until((d) =>
- {
- try
- {
- if (parentElement == null)
- {
- return d.FindElement(By.Id(id));
- }
- else
- {
- return parentElement.FindElement(By.Id(id));
- }
- }
- catch {
- return null;
- }
- });
- }
- static IWebElement waitGetElementByName(WebDriverWait wait, string name, IWebElement parentElement = null)
- {
- return wait.Until((d) =>
- {
- try
- {
- if (parentElement == null)
- {
- return d.FindElement(By.Name(name));
- }
- else
- {
- return parentElement.FindElement(By.Name(name));
- }
- }
- catch
- {
- return null;
- }
- });
- }
- static IWebElement waitGetElementByTagName(WebDriverWait wait, string name, IWebElement parentElement = null)
- {
- return wait.Until((d) =>
- {
- try
- {
- if (parentElement == null)
- {
- return d.FindElement(By.TagName(name));
- }
- else
- {
- return parentElement.FindElement(By.TagName(name));
- }
- }
- catch
- {
- return null;
- }
- });
- }
- static ReadOnlyCollection<IWebElement> waitGetElementsByName(WebDriverWait wait, string name, IWebElement parentElement = null)
- {
- return wait.Until((d) =>
- {
- try
- {
- if (parentElement == null)
- {
- return d.FindElements(By.Name(name));
- }
- else
- {
- return parentElement.FindElements(By.Name(name));
- }
- }
- catch
- {
- return null;
- }
- });
- }
- static ReadOnlyCollection<IWebElement> waitGetElementsByTagName(WebDriverWait wait, string name, IWebElement parentElement = null)
- {
- return wait.Until((d) =>
- {
- try
- {
- if (parentElement == null)
- {
- return d.FindElements(By.TagName(name));
- }
- else
- {
- return parentElement.FindElements(By.TagName(name));
- }
- }
- catch
- {
- return null;
- }
- });
- }
- static IWebElement waitGetElementByClassName(WebDriverWait wait, string name, IWebElement parentElement = null)
- {
- return wait.Until((d) =>
- {
- try
- {
- if (parentElement == null)
- {
- return d.FindElement(By.ClassName(name));
- }
- else
- {
- return parentElement.FindElement(By.ClassName(name));
- }
- }
- catch
- {
- return null;
- }
- });
- }
- /// <summary>
- /// 获取指定案号的专利申请案的基本信息和初稿文件、定稿文件和第一次返稿文件
- /// </summary>
- /// <param name="caseNo"></param>
- /// <returns></returns>
- /// <exception cref="Exception"></exception>
- public static dynamic DownloadCaseFiles(string caseNo)
- {
- dynamic retObject = new ExpandoObject();
- retObject.CaseNo = caseNo.Trim();
- using (IWebDriver driver = CreateChromeDriver())
- {
- try
- {
- WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(5));
-
- Login(driver, wait);
- //点击顶部菜单栏中的案件管理菜单
- IWebElement linkCaseManager = waitGetElementByName(wait, "71A7CC35-F597-40E1-9FEF-BE622A3A3B63");
- linkCaseManager.Click();
- IWebElement linkCaseSearch = wait.Until((d) =>
- {
- try
- {
- return driver.FindElement(By.LinkText("案件查询"));
- }
- catch
- {
- return null;
- }
- });
- driver.ExecuteJavaScript("arguments[0].click();", linkCaseSearch);
- //linkCaseSearch.Click();
- IWebElement patentSearch = waitGetElementByName(wait, "4df7eee3-426f-4ce5-9204-34ccb0fd27f7");
- driver.ExecuteJavaScript("arguments[0].click();", patentSearch);
- //patentSearch.Click();
- driver.SwitchTo().Frame(1);
- var inputSearch = waitGetElementById(wait, "case_volume");//driver.FindElement(By.Id("case_volume"));
- inputSearch.SendKeys(caseNo.Trim());
- var btnSearch = waitGetElementById(wait, "btn_Search");// driver.FindElement(By.Id("btn_Search"));
- driver.ExecuteJavaScript("arguments[0].click();",btnSearch);
- //btnSearch.Click();
-
- try
- {
- var caseLink = wait.Until((d) =>
- {
- return d.FindElement(By.XPath($"//a[contains(text(),'{caseNo}')]"));
- });
- driver.ExecuteJavaScript("arguments[0].click();", caseLink);
- }
- catch(Exception ex)
- {
- if(ex.Message.Contains("no such element: Unable to locate element"))
- {
- return retObject;
- }
- }
- System.Threading.Thread.Sleep(1000);
- driver.SwitchTo().ParentFrame();
- driver.SwitchTo().Frame(2);
- //案件名称
- retObject.CaseName = waitGetElementById(wait, "p_case_info__case_name").GetAttribute("value");
- //我方文号
- retObject.CaseNo = waitGetElementById(wait, "p_case_info__case_volume").GetAttribute("value");
- //案件类型
- retObject.CaseType = waitGetElementById(wait, "p_case_info__case_type_id").GetAttribute("value");
- //申请类型
- var selectElement = waitGetElementById(wait, "p_case_info__apply_type_id");
- retObject.ApplicationType = new SelectElement(selectElement).SelectedOption.Text;
- //客户
- retObject.Customer = waitGetElementById(wait, "p_case_info__customer_id").GetAttribute("value").Replace("(null)", "");
- //申请国家
- retObject.Country = waitGetElementById(wait, "p_case_info__country_id").GetAttribute("value");
- var table = waitGetElementById(wait, "table_ProcList");
- var rows = waitGetElementsByTagName(wait, "tr", table);// table.FindElements(By.TagName("tr"));
- foreach (var row in rows)
- {
- var cells = row.FindElements(By.TagName("td"));
- if (cells[1].Text == "新申请")
- {
- var bthEdit = waitGetElementByClassName(wait, "tbedit", cells[12]);
- driver.ExecuteJavaScript("arguments[0].click();", bthEdit);
- break;
- }
- }
- driver.SwitchTo().ParentFrame().SwitchTo().Frame(0);
- //案件阶段
- var caseStage = waitGetElementById(wait, "select2-p_proc_info__review_stage-container");
- if (caseStage != null && caseStage.Text != "--请选择--")
- {
- retObject.CaseStage = caseStage.Text;
- }
- //内部期限
- retObject.InternalDate = waitGetElementById(wait, "p_proc_info__int_due_date").GetAttribute("value");
- //处理事项系数
- var DICoe = waitGetElementById(wait, "p_proc_info__proc_coefficient_id");
- retObject.DoItemCoefficient = new SelectElement(DICoe).SelectedOption.Text;
- if (retObject.DoItemCoefficient == "请选择")
- {
- retObject.DoItemCoefficient = "";
- }
- retObject.DoPersons = waitGetElementById(wait, "pic_list").GetAttribute("value"); //处理人
- retObject.Reviewer = waitGetElementById(wait, "rev_list").GetAttribute("value"); //核稿人
- //第一次初稿日
- retObject.FirstDraftDate = waitGetElementById(wait, "p_proc_info__first_doc_date").GetAttribute("value");
- //客户期限
- retObject.CustomerLimitDate = waitGetElementById(wait, "p_proc_info__cus_due_date").GetAttribute("value");
- //配案日
- retObject.CaseAssigmentDate = waitGetElementById(wait, "p_proc_info__allocate_date").GetAttribute("value");
- //返稿日
- retObject.ReturnDate = waitGetElementById(wait, "p_proc_info__back_date").GetAttribute("value");
- //定稿日
- retObject.FinalizationDate = waitGetElementById(wait, "p_proc_info__finish_doc_date").GetAttribute("value");
- //点击附件信息Tab
- var lifile = driver.FindElement(By.Id("lifile"));
- driver.ExecuteJavaScript("arguments[0].click();", lifile);
- //添加从文件清单中获取
- //“新申请第一次内审(初稿)、
- //新申请第一次返稿(第一次发客户文档)、
- //新申请文档(定稿文档)”
- var table_filelist = waitGetElementById(wait, "table_filelist");
- //定稿文件
- try
- {
- Download(retObject, driver, wait, table_filelist, "新申请文档");
- }
- catch { }
- //新申请第一次返稿文件
- try
- {
- Download(retObject, driver, wait, table_filelist, "新申请第一次返稿");
- }
- catch { }
- //初稿文件
- try
- {
- waitGetElementById(wait, "draftfiletoggle").Click();
- var table_draffilelist = waitGetElementById(wait, "table_draftfilelist");// driver.FindElement(By.Id("table_draftfilelist"));
- Download(retObject, driver, wait, table_draffilelist, "新申请第一次内审");
- }
- catch { }
- }
- catch (Exception ex)
- {
- throw new Exception(ex.Message, ex);
- }
- finally
- {
- driver.Quit();
- killChromProcess();
- }
- }
- return retObject;
- }
- /// <summary>
- /// 获取当前为递交中或前一天完成的新申请案件清单
- /// </summary>
- /// <param name="type">类型0:递交中、1:前一天完成</param>
- /// <returns></returns>
- /// <exception cref="Exception"></exception>
- public static DataTable GetFinished3FilesCases(int type)
- {
- DataTable retObject = new DataTable();
-
- using (IWebDriver driver = CreateChromeDriver())
- {
- try
- {
- WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(5));
- Login(driver, wait);
- //点击顶部菜单栏中的案件管理菜单
- IWebElement linkCaseManager = waitGetElementByName(wait, "71A7CC35-F597-40E1-9FEF-BE622A3A3B63");
- linkCaseManager.Click();
- IWebElement linkCaseSearch = wait.Until((d) =>
- {
- try
- {
- return driver.FindElement(By.LinkText("案件查询"));
- }
- catch
- {
- return null;
- }
- });
- driver.ExecuteJavaScript("arguments[0].click();", linkCaseSearch);
- //linkCaseSearch.Click();
- IWebElement patentSearch = waitGetElementByName(wait, "4df7eee3-426f-4ce5-9204-34ccb0fd27f7");
- driver.ExecuteJavaScript("arguments[0].click();", patentSearch);
- //patentSearch.Click();
- driver.SwitchTo().Frame(1);
- #region 添加检索条件
- var chkDoItem = waitGetElementById(wait, "is_proc");
- chkDoItem.Click();
- var ictrlproc = waitGetElementById(wait, "i_ctrl_proc");
- ictrlproc.Click();
- var chkXSQ = waitGetElementById(wait, "ctrl_proc_id_3_check");
- chkXSQ.Click();
-
- var btnOk = waitGetElementById(wait, "ctrl_proc_ida_ok");
- btnOk.Click();
- waitGetElementById(wait,"proc_status").Click();
- if (type == 0)
- {
- waitGetElementById(wait, "procstatus_5_check").Click();
- waitGetElementById(wait, "procstatusa_ok").Click() ;
- }
- else
- {
- if(type == 1)
- {
- waitGetElementById(wait, "procstatus_12_check").Click();
- waitGetElementById(wait, "procstatusa_ok").Click();
- Log($"{DateTime.Now}\t输入处理事项完成日期:开始日期");
- var startDate = wait.Until((d) => {
- return d.FindElement(By.Id("finish_date_start"));
- });
- startDate.Click();
- startDate.SendKeys(DateTime.Now.AddDays(-1).ToString("yyyy-MM-dd"));
- Log($"{DateTime.Now}\t输入处理事项完成日期:结束日期");
- var endDate = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.Id("finish_date_end"));
- }
- catch
- {
- return null;
- }
- });
- endDate.Click();
- endDate.SendKeys(DateTime.Now.AddDays(-1).ToString("yyyy-MM-dd"));
- }
- }
- waitGetElementById(wait,"procstatusa_ok").Click();
- #endregion
- #region 导出检索结果
- var btnSearch = waitGetElementById(wait, "btn_Search");// driver.FindElement(By.Id("btn_Search"));
- driver.ExecuteJavaScript("arguments[0].click();", btnSearch);
- Log($"{DateTime.Now}\t切换到弹出的导出报表窗口,点击导出按钮");
- var btnExport = waitGetElementById(wait, "btn_Export");
- driver.ExecuteJavaScript("arguments[0].click();", btnExport);
- Log($"{DateTime.Now}\t切换到弹出的导出报表窗口,点击导出按钮");
- driver.SwitchTo().DefaultContent();
- var ihg_export = driver.FindElement(By.Name("ihg_export"));
- driver.SwitchTo().Frame(ihg_export);
- waitGetElementById(wait, "btnSubmit").Click();
- //切换到弹出的下载报表界面,点击下载按钮
- Log($"{DateTime.Now}\t切换到弹出的下载报表界面,点击下载按钮");
- //System.Threading.Thread.Sleep(3000);
- driver.SwitchTo().DefaultContent();
- var frameDownload = waitGetElementByName(wait, "DownloadList");
- driver.SwitchTo().Frame(frameDownload);
- //driver.FindElement(By.CssSelector("table tbody tr:first-child"));
- var firstTr = wait.Until((d) => {
- return d.FindElement(By.CssSelector("table tbody tr"));
- });
- var tdStatus = firstTr.FindElement(By.XPath(".//td")).FindElement(By.XPath("following-sibling::td[4]"));
- string strStatus = tdStatus.Text;
- while (strStatus.Trim() != "导出成功!")
- {
- if (strStatus.Trim() == "导出失败,请稍后重试!")
- {
- return null;
- }
- System.Threading.Thread.Sleep(5000);
- firstTr = wait.Until((d) => {
- return d.FindElement(By.CssSelector("table tbody tr"));
- });
- tdStatus = firstTr.FindElement(By.XPath(".//td")).FindElement(By.XPath("following-sibling::td[4]"));
- strStatus = tdStatus.Text;
- }
- Log($"{DateTime.Now}\t点击下载按钮下载文档");
- firstTr = wait.Until((d) => {
- return d.FindElement(By.CssSelector("table tbody tr"));
- });
- wait.Until((d)=>{
- return firstTr.FindElement(By.XPath(".//td/a[@title='下载']"));
- }).Click();
- var ReportName = $"案件清单({DateTime.Now.ToString("yyyy年MM月dd日")})";
- string strFilePath = System.IO.Path.Combine(strFileSavePath, $"{ReportName.Trim()}.xlsx");
- WaitForFileDownload(strFileSavePath, $"{ReportName.Trim()}.xlsx", TimeSpan.FromMinutes(5));
- //删除下载记录
- Log($"{DateTime.Now}\t删除下载记录");
- firstTr = wait.Until((d) => {
- return d.FindElement(By.CssSelector("table tbody tr"));
- });
- wait.Until((d) => {
- return firstTr.FindElement(By.XPath(".//td/a[@title='删除']"));
- }).Click();
- #endregion
- #region 将下载的excel档转换成Datatable
- retObject = NPOIExcel.ExcelToDataTable(strFilePath.Replace("~", "_"), true,true,1);
- System.IO.File.Delete(strFilePath.Replace("~", "_"));
- #endregion
- }
- catch (Exception ex)
- {
- throw new Exception(ex.Message, ex);
- }
- finally
- {
- driver.Quit();
- killChromProcess();
- }
- }
- return retObject;
- }
- private static void Download(dynamic retObject, IWebDriver driver, WebDriverWait wait, IWebElement table_filelist, string fileType)
- {
- var tBody = waitGetElementByTagName(wait, "tbody", table_filelist);
- var finallyFile = wait.Until((d) =>
- {
- try {
- return tBody.FindElement(By.XPath($".//td[@colname='file_desc'][normalize-space()='{fileType}']"));
- }
- catch
- {
- return null;
- }
- });
-
- if(finallyFile == null)
- {
- switch (fileType)
- {
- case "新申请文档":
- retObject.finallyFile = null;
- break;
- case "新申请第一次返稿":
- retObject.firstReturnFile = null;
- break;
- case "新申请第一次内审":
- retObject.draftFile = null;
- break;
- }
- return;
- }
-
- var tdfileName = wait.Until((d) =>
- {
- try
- {
- return finallyFile.FindElement(By.XPath("preceding-sibling::*[2]"));
- }
- catch
- {
- return null;
- }
- });
- string fileName = tdfileName.Text;
- while (string.IsNullOrEmpty(fileName))
- {
- System.Threading.Thread.Sleep(100);
- fileName = tdfileName.Text;
- }
- string filePath = System.IO.Path.Combine(strFileSavePath, fileName);
- if (System.IO.File.Exists(filePath))
- {
- System.IO.File.Delete(filePath);
- }
- switch (fileType)
- {
- case "新申请文档":
- retObject.finallyFile = filePath;
- break;
- case "新申请第一次返稿":
- retObject.firstReturnFile = filePath;
- break;
- case "新申请第一次内审":
- retObject.draftFile = filePath;
- break;
- }
-
- var btnDownload = finallyFile.FindElement(By.XPath("following-sibling::*[4]"));
- btnDownload = waitGetElementByClassName(wait, "tbdownload", btnDownload);
- driver.ExecuteJavaScript("arguments[0].click();", btnDownload);
- WaitForFileDownload(strFileSavePath, fileName, TimeSpan.FromMinutes(5));
- }
- private static void Login(IWebDriver driver, WebDriverWait wait)
- {
- //进入登录界面
- driver.Navigate().GoToUrl(ConfigHelper.GetSectionValue("IPEasySetting:IPEasyWeb"));
- //输入用户名和密码
- waitGetElementById(wait, "txtUser").SendKeys(Account);
- waitGetElementById(wait, "txtPwd").SendKeys(Password);
- //点击登录按钮
- waitGetElementById(wait, "btnLogin").Click();
- //关闭提示遮罩层
- waitGetElementById(wait, "jpwClose").Click();
- }
- public static void DownloadReport(string strId,string filename)
- {
- using (IWebDriver driver = CreateChromeDriver())
- {
- try
- {
- WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(10));
-
- Login(driver, wait);
- //点击顶部菜单栏中的报表管理菜单
- waitGetElementById(wait, "970d33d5-c728-41b8-a060-4330610706b9").Click();
- //driver.FindElement(By.Name("970d33d5-c728-41b8-a060-4330610706b9")).Click();
- //点击左侧 自定义报表 菜单
- waitGetElementByName(wait, "642fa96f-1e1f-46fd-aaa4-cb461ee8df5b").Click();
- //driver.FindElement(By.Name("642fa96f-1e1f-46fd-aaa4-cb461ee8df5b")).Click();
- //切换到自定义报表Frame
- driver.SwitchTo().Frame(1);
- //调用报表导出JS
- ((IJavaScriptExecutor)driver).ExecuteScript($"Report.Export('{strId}');");
- //切换到弹出的导出报表窗口,点击导出按钮
- driver.SwitchTo().DefaultContent();
- var ihg_export = waitGetElementByName(wait, "ihg_export"); //driver.FindElement(By.Name("ihg_export"));
- driver.SwitchTo().Frame(ihg_export);
- waitGetElementById(wait, "btnSubmit").Click();
- //driver.FindElement(By.Id("btnSubmit")).Click();
- WaitForFileDownload(strFileSavePath, filename, TimeSpan.FromMinutes(5));
- }
- catch (Exception ex)
- {
- throw new Exception(ex.Message);
- }
- finally
- {
- driver.Quit();
- driver.Dispose();
- killChromProcess();
- }
- }
- }
- private static void Log(string strMessage)
- {
- StreamWriter sw = File.AppendText("c:\\temp\\log.txt");
- sw.WriteLine($"{strMessage}");
- sw.Flush();
- sw.Close();
- sw.Dispose();
- }
- private static OpenQA.Selenium.Chrome.ChromeDriver CreateChromeDriver()
- {
- bool isheadless = (ConfigHelper.GetSectionValue("IPEasySetting:isHeadless") == "true");
-
- var options = new OpenQA.Selenium.Chrome.ChromeOptions();
- options.AddUserProfilePreference("profile.default_content_settings.popups", 0);
- options.AddUserProfilePreference("profile.default_content_setting_values.automatic_downloads", 1);
- options.AddUserProfilePreference("download.prompt_for_download", false); // 禁止下载提示
- options.AddUserProfilePreference("download.default_directory", strFileSavePath);
- options.AddUserProfilePreference("intl.accept_languages", "nl");
- options.AddUserProfilePreference("disable-popup-blocking", "true");
- options.AddUserProfilePreference("safebrowsing.enabled", true);
- options.AddArgument($"--unsafely-treat-insecure-origin-as-secure={ConfigHelper.GetSectionValue("IPEasySetting:IPEasyWeb").Replace("/Login.aspx", "")}");//替换自己的域名,多域名可用逗号分隔。
- if (isheadless)
- {
- options.AddArgument("headless");
- }
- var driver = new OpenQA.Selenium.Chrome.ChromeDriver(ConfigHelper.GetSectionValue("IPEasySetting:ChormeDriverPath"), options);
- driver.Manage().Window.Maximize();
- driver.Manage().Timeouts().ImplicitWait = TimeSpan.FromSeconds(50);
- driver.Manage().Timeouts().PageLoad = TimeSpan.FromSeconds(100);
-
- return driver;
- }
- /// <summary>
- /// 根据报表名称导出报表
- /// </summary>
- /// <param name="ReportName">报告名称</param>
- /// <param name="isModifyDate">是否手动修改日期范围</param>
- public static DataTable DownloadReport(string ReportName,bool isModifyDate)
- {
- Log($"{DateTime.Now}\t开始下载:{ReportName}");
- DataTable retDatatable;
- Log($"{DateTime.Now}\t开始启动Chrome");
- using (IWebDriver driver = CreateChromeDriver())
- {
- try
- {
- WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(10));
-
- Login(driver, wait);
- //点击顶部菜单栏中的报表管理菜单
- Log($"{DateTime.Now}\t点击顶部菜单栏中的报表管理菜单");
- var reportMenu = waitGetElementByName(wait, "970d33d5-c728-41b8-a060-4330610706b9");
- //driver.FindElement(By.Name("970d33d5-c728-41b8-a060-4330610706b9"));
- driver.ExecuteJavaScript("arguments[0].click();", reportMenu);
- //点击左侧 自定义报表 菜单
- Log($"{DateTime.Now}\t点击左侧 自定义报表 菜单");
- var customerReportMenu = waitGetElementByName(wait, "642fa96f-1e1f-46fd-aaa4-cb461ee8df5b");
- driver.ExecuteJavaScript("arguments[0].click();", customerReportMenu);
- //切换到自定义报表Frame
- Log($"{DateTime.Now}\t切换到自定义报表Frame");
- driver.SwitchTo().Frame(1);
- Log($"{DateTime.Now}\t开始搜索报告");
- var inputSearch = waitGetElementById(wait,"customizedList_TxtSheetSearchKey");
- Log($"{DateTime.Now}\t在搜索框中输入报告名称");
- inputSearch.SendKeys(ReportName);
- Log($"{DateTime.Now}\t点击搜索按钮");
- var btnSearch = waitGetElementByClassName(wait,"btn-search");
- btnSearch.Click();
- Log($"{DateTime.Now}\t选中报告");
- var reportRecord = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.XPath($"//td[contains(text(),'{ReportName}')]"));
- }
- catch
- {
- return null;
- }
- });
- reportRecord.Click();
- if (isModifyDate)
- {
- Log($"{DateTime.Now}\t点击编辑");
- var btnEdit = waitGetElementByClassName(wait,"edit");
- btnEdit.Click();
- Log($"{DateTime.Now}\t清除以选择的处理事项完成日条件");
- try
- {
- var doItemFinished = wait.Until((d) => {
- return d.FindElement(By.XPath("//span[contains(@objcvalue,'_date') and contains(@id,'ST;')]"));
- });
- doItemFinished.Click();
- }
- catch { }
- Log($"{DateTime.Now}\t输入处理事项完成日期:开始日期");
- var startDate = wait.Until((d) => {
- return d.FindElement(By.XPath("//input[contains(@id,'dt_s_')]"));
- });
- driver.ExecuteJavaScript("arguments[0].scrollIntoView();", startDate);
- startDate.Click();
- System.Threading.Thread.Sleep(3000);
- startDate.SendKeys(new DateTime(DateTime.Now.AddMonths(-1).Year, DateTime.Now.AddMonths(-1).Month, 1).ToString("yyyy-MM-dd"));
- Log($"{DateTime.Now}\t输入处理事项完成日期:结束日期");
- var endDate = wait.Until((d) =>
- {
- try
- {
-
- return d.FindElement(By.XPath("//input[contains(@id,'dt_e_')]"));//.Id("dt_e_4F8FE88D-9040-45F1-9723-45699BCD4CAF"));
- }
- catch
- {
- return null;
- }
- });
- System.Threading.Thread.Sleep(3000);
- endDate.Click();
- endDate.SendKeys(new DateTime(DateTime.Now.Year, DateTime.Now.Month, 1).AddDays(-1).ToString("yyyy-MM-dd"));
- Log($"{DateTime.Now}\t添加处理事项检索条件");
- var addDate = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.XPath("//a[contains(@onclick,'ReportSub.ConditionDTSelect')]"));
- }
- catch
- {
- return null;
- }
- });
- addDate.Click();
- //System.Threading.Thread.Sleep(500);
- Log($"{DateTime.Now}\t保存检索条件");
- var btnSave = waitGetElementById(wait, "save"); // driver.FindElement(By.Id("save"));
- btnSave.Click();
- //System.Threading.Thread.Sleep(3000);
- }
- Log($"{DateTime.Now}\t点击导出Excel链接");
- var linkExport = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.XPath("//a[contains(@onclick,'-') and @class='tbexcel']"));
- }
- catch
- {
- return null;
- }
- });
- driver.ExecuteJavaScript("arguments[0].click();",linkExport);
- //linkExport.Click();
- //切换到弹出的导出报表窗口,点击导出按钮
- Log($"{DateTime.Now}\t切换到弹出的导出报表窗口,点击导出按钮");
- driver.SwitchTo().DefaultContent();
- var ihg_export = driver.FindElement(By.Name("ihg_export"));
- driver.SwitchTo().Frame(ihg_export);
- waitGetElementById(wait, "btnSubmit").Click();
- //切换到弹出的下载报表界面,点击下载按钮
- Log($"{DateTime.Now}\t切换到弹出的下载报表界面,点击下载按钮");
- //System.Threading.Thread.Sleep(3000);
- driver.SwitchTo().DefaultContent();
- var frameDownload = waitGetElementByName(wait,"DownloadList");
- driver.SwitchTo().Frame(frameDownload);
- var firstTr = wait.Until((d) => {
- return d.FindElement(By.CssSelector("table tbody tr"));
- });
- var tdStatus = wait.Until((d) => {
- return firstTr.FindElement(By.XPath(".//td")).FindElement(By.XPath("following-sibling::td[4]"));
- });
-
- string strStatus = tdStatus.Text;
- while (strStatus.Trim() != "导出成功!")
- {
- if (strStatus.Trim() == "导出失败,请稍后重试!")
- {
- return null;
- }
- System.Threading.Thread.Sleep(5000);
- firstTr = wait.Until((d) => {
- return d.FindElement(By.CssSelector("table tbody tr"));
- });
- tdStatus = wait.Until((d) => {
- return firstTr.FindElement(By.XPath(".//td")).FindElement(By.XPath("following-sibling::td[4]"));
- });
- strStatus = tdStatus.Text;
- }
- Log($"{DateTime.Now}\t点击下载按钮下载文档");
- firstTr = wait.Until((d) => {
- return d.FindElement(By.CssSelector("table tbody tr"));
- });
- firstTr.FindElement(By.XPath(".//td/a[@title='下载']")).Click();
- //System.Threading.Thread.Sleep(5000);
- //btnDownload.Click();
-
- string strFilePath = System.IO.Path.Combine(strFileSavePath, $"{ReportName.Trim()}.xlsx");
- WaitForFileDownload(strFileSavePath, $"{ReportName.Trim()}.xlsx", TimeSpan.FromMinutes(5));
-
- //删除下载记录
- Log($"{DateTime.Now}\t删除下载记录");
- firstTr = wait.Until((d) => {
- return d.FindElement(By.CssSelector("table tbody tr"));
- });
- firstTr.FindElement(By.XPath(".//td/a[@title='删除']")).Click();
- //System.IO.FileInfo file = new System.IO.FileInfo(strFilePath.Replace("~", "_"));
- retDatatable = NPOIExcel.ExcelToDataTable(strFilePath.Replace("~", "_"), true);
- System.IO.File.Delete(strFilePath.Replace("~", "_"));
- }
- catch (Exception ex)
- {
- Log(ex.ToString());
- throw new Exception(ex.Message, ex);
- }
- finally
- {
- Log("关闭Chrome");
- driver.Quit();
- driver.Dispose();
- killChromProcess();
- }
- }
- Log($"{DateTime.Now}\t返回数据");
- return retDatatable;
-
- }
- /// <summary>
- /// 获取案件基本信息
- /// </summary>
- /// <param name="caseNo">我方文号</param>
- /// <returns></returns>
- public static dynamic GetCaseInfo(string caseNo)
- {
- dynamic retObject = new ExpandoObject();
- retObject.CaseNo = caseNo.Trim();
- using (IWebDriver driver = CreateChromeDriver())
- {
- try
- {
- WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(10));
-
- Login(driver, wait);
- //点击顶部菜单栏中的案件管理菜单
- waitGetElementByName(wait, "71A7CC35-F597-40E1-9FEF-BE622A3A3B63").Click();
- //点击左侧 查询 菜单
- waitGetElementByName(wait, "c3266ab3-521a-4815-8aaf-7dd0bc5a76af").Click();
- //切换到自定义报表Frame
- driver.SwitchTo().Frame(1);
- var inputSearch = waitGetElementById(wait,"case_volume");
- inputSearch.SendKeys(caseNo.Trim());
- var btnSearch = waitGetElementById(wait, "btn_Search");
- btnSearch.Click();
- var caseLink = wait.Until((d) => {
- return d.FindElement(By.XPath($"//a[contains(text(),'{caseNo}')]"));
- });
- caseLink.Click();
- driver.SwitchTo().ParentFrame().SwitchTo().Frame(2);
- //等待页面上ID属性值为submitButton的元素加载完成
- IWebElement myElement = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.Id("libase"));
- }
- catch {
- return null;
- }
-
- });
- myElement.Click();
- //driver.FindElement(By.Id("libase")).Click();
- retObject.CaseName = driver.FindElement(By.Id("p_case_info__case_name")).GetAttribute("value"); //案件名称
- retObject.CustomerName = driver.FindElement(By.Id("p_case_info__customer_id")).GetAttribute("value").Replace("(null)",""); //客户名称
- retObject.BusinessType = driver.FindElement(By.Id("p_case_info__business_type_id")).GetAttribute("value"); //业务类型
- retObject.CaseState = GetSelectText(driver.FindElement(By.Id("p_case_info__case_status_id")));
- retObject.ApplicationType = GetSelectText(driver.FindElement(By.Id("p_case_info__apply_type_id")));
- retObject.CaseType = driver.FindElement(By.Id("p_case_info__case_type_id")).GetAttribute("value"); //案件类型
- retObject.EntrustingDate = driver.FindElement(By.Id("p_case_info__charge_date")).GetAttribute("value"); //委案日期
- retObject.CaseMemo = driver.FindElement(By.Id("p_case_info__remark")).GetAttribute("value"); //案件备注
- driver.FindElement(By.XPath($"//span[contains(text(),'扩展信息')]")).Click();
- //select[@id='p_case_info__case_coefficient_id']
- retObject.CaseCoefficient = GetSelectText(driver.FindElement(By.Id("p_case_info__case_coefficient_id")));
- }
- catch (Exception ex)
- {
- throw new Exception(ex.Message, ex);
- }
- finally
- {
- driver.Quit();
- killChromProcess();
- }
- }
- return retObject;
- }
- public static dynamic GetPerformanceRecord(string caseNo, List<string> doItemNames)
- {
- dynamic retObject = new ExpandoObject();
- retObject.CaseNo = caseNo.Trim();
- using (var Service = ChromeDriverService.CreateDefaultService(ConfigHelper.GetSectionValue("IPEasySetting:ChormeDriverPath")))
- {
- Service.Start();
- using (IWebDriver driver = CreateChromeDriver())
- {
- try
- {
- WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(10));
-
- Login(driver,wait);
- //点击顶部菜单栏中的案件管理菜单
- waitGetElementByName(wait,"71A7CC35-F597-40E1-9FEF-BE622A3A3B63").Click();
- //点击左侧 查询 菜单
- waitGetElementByName(wait, "c3266ab3-521a-4815-8aaf-7dd0bc5a76af").Click();
- driver.SwitchTo().Frame(1);
- var inputSearch = wait.Until((d) =>
- {
- try
- {
- //切换到自定义报表Frame
- return d.FindElement(By.Id("case_volume"));
- }
- catch
- {
- return null;
- }
- });
- inputSearch.SendKeys(caseNo.Trim());
- var btnSearch = waitGetElementById(wait,"btn_Search");
- btnSearch.Click();
- var caseLink = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.XPath($"//a[normalize-space()='{caseNo.Trim()}']"));
- }
- catch
- {
- return null;
- }
- });
- caseLink = driver.FindElement(By.XPath($"//a[normalize-space()='{caseNo.Trim()}']"));
- caseLink.Click();
- driver.SwitchTo().ParentFrame().SwitchTo().Frame(2);
- IWebElement temDoItemLink = null;
- string temFinishedDate = "";
- string xpathQuery = "";
- foreach (string doItemName in doItemNames)
- {
- xpathQuery = string.IsNullOrEmpty(xpathQuery) ? $"normalize-space()='{doItemName}'" : $"{xpathQuery} or normalize-space()='{doItemName}'";
- }
- //foreach (string doItemName in doItemNames)
- //{
- var DoItemLinks = wait.Until((d) =>
- {
- d.SwitchTo().ParentFrame().SwitchTo().Frame(2);
- return d.FindElements(By.XPath($"//td[@colname='ctrl_proc' and ({xpathQuery})]"));
- });
-
- if (DoItemLinks.Count > 0)
- {
- var DoItemLink = DoItemLinks[DoItemLinks.Count - 1];
- if (string.IsNullOrEmpty(temFinishedDate))
- {
- temFinishedDate = DoItemLink.FindElement(By.XPath("following-sibling::td[7]")).Text;
- temDoItemLink = DoItemLink;
- }
- else
- {
- if (DoItemLink.FindElement(By.XPath("following-sibling::td[7]")).Text.CompareTo(temFinishedDate) > 0)
- {
- temFinishedDate = DoItemLink.FindElement(By.XPath("following-sibling::td[7]")).Text;
- temDoItemLink = DoItemLink;
- }
- }
- }
- //}
- if(temDoItemLink != null)
- {
- retObject.CaseStage = temDoItemLink.FindElement(By.XPath("following-sibling::td[1]")).Text; //案件阶段
- retObject.DoItemState = temDoItemLink.FindElement(By.XPath("following-sibling::td[2]")).Text; //处理事项处理状态
- retObject.InternalDate = temDoItemLink.FindElement(By.XPath("following-sibling::td[4]")).Text; //内部期限
- retObject.CustomerLimitDate = temDoItemLink.FindElement(By.XPath("following-sibling::td[5]")).Text; //客户期限
- retObject.FinishedDate = temDoItemLink.FindElement(By.XPath("following-sibling::td[7]")).Text; //处理事项完成日
- retObject.DoPersons = temDoItemLink.FindElement(By.XPath("following-sibling::td[8]")).Text; //处理人
- retObject.ExternalHandler = temDoItemLink.FindElement(By.XPath("following-sibling::td[9]")).Text; //对外处理人
- retObject.Reviewer = temDoItemLink.FindElement(By.XPath("following-sibling::td[10]")).Text; //核稿人
- retObject.DoItemMemo = temDoItemLink.FindElement(By.XPath("following-sibling::td[12]")).Text; //处理事项备注
- retObject.DoItem = temDoItemLink.Text;
- //temDoItemLink = DoItemLink;
- temDoItemLink.Click();
- }
- else
- {
- throw new ApplicationException("处理事项不存在!");
- }
- var p_proc_finish_doc_date = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.Id("p_proc_info__finish_doc_date"));
- }
- catch
- {
- return null;
- }
- });
- //System.Threading.Thread.Sleep(500);
- retObject.FinalizationDate = p_proc_finish_doc_date.GetAttribute("value"); //定稿日
- retObject.ReturnDate = driver.FindElement(By.Id("p_proc_info__back_date")).GetAttribute("value"); //返稿日
- retObject.Reviewer = driver.FindElement(By.Id("p_proc_info__revise_user")).GetAttribute("value"); //核稿人
-
- retObject.DoItemCoefficient = driver.FindElement(By.Id("p_proc_info__proc_coefficient")).GetAttribute("value"); //处理事项系数
- retObject.WordCount = driver.FindElement(By.Id("p_proc_info__translate_count")).GetAttribute("value"); //翻译字数
- driver.FindElement(By.Id("libase")).Click();
- var p_case_info__case_name = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.Id("p_case_info__case_name"));
- }
- catch
- {
- return null;
- }
- });
- retObject.CaseName = p_case_info__case_name.GetAttribute("value"); //案件名称
- retObject.CustomerName = driver.FindElement(By.Id("p_case_info__customer_id")).GetAttribute("value"); //客户名称
- retObject.BusinessType = driver.FindElement(By.Id("p_case_info__business_type_id")).GetAttribute("value"); //业务类型
- retObject.CaseState = GetSelectText(driver.FindElement(By.Id("p_case_info__case_status_id")));
- retObject.ApplicationType = GetSelectText(driver.FindElement(By.Id("p_case_info__apply_type_id")));
- retObject.CaseType = driver.FindElement(By.Id("p_case_info__case_type_id")).GetAttribute("value"); //案件类型
- retObject.EntrustingDate = driver.FindElement(By.Id("p_case_info__charge_date")).GetAttribute("value"); //委案日期
- retObject.CaseMemo = driver.FindElement(By.Id("p_case_info__remark")).GetAttribute("value"); //案件备注
- driver.FindElement(By.XPath($"//span[contains(text(),'扩展信息')]")).Click();
- //select[@id='p_case_info__case_coefficient_id']
- retObject.CaseCoefficient = GetSelectText(driver.FindElement(By.Id("p_case_info__case_coefficient_id")));
- }
- catch (Exception ex)
- {
- throw new Exception(ex.Message, ex);
- }
- finally
- {
- driver.Quit();
- killChromProcess();
- }
- }
- Service.Dispose();
- }
- return retObject;
- }
- /// <summary>
- /// 获取案件处理事项记录
- /// </summary>
- /// <param name="caseNo">我方文号</param>
- /// <param name="doItemName">处理事项</param>
- /// <returns></returns>
- public static dynamic GetPerformanceRecord(string caseNo,string doItemName,string caseStage=null)
- {
- if (caseNo.Contains("APCN"))
- {
- //商标
- return GetAPCNPerformanceRecord(caseNo, doItemName, caseStage);
- }
-
- dynamic retObject = new ExpandoObject();
- retObject.CaseNo = caseNo.Trim();
- retObject.DoItem = doItemName;
- using (var Service = ChromeDriverService.CreateDefaultService(ConfigHelper.GetSectionValue("IPEasySetting:ChormeDriverPath")))
- {
- Service.Start();
- using (IWebDriver driver = CreateChromeDriver())
- {
- try
- {
- WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(10));
- Login(driver, wait);
- //点击顶部菜单栏中的案件管理菜单
- waitGetElementByName(wait,"71A7CC35-F597-40E1-9FEF-BE622A3A3B63").Click();
- //点击左侧 查询 菜单
- waitGetElementByName(wait, "c3266ab3-521a-4815-8aaf-7dd0bc5a76af").Click();
- driver.SwitchTo().Frame(1);
- var inputSearch = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.Id("case_volume"));
- }
- catch
- {
- return null;
- }
- });
-
- inputSearch.SendKeys(caseNo.Trim());
- var btnSearch = waitGetElementById(wait,"btn_Search");
- btnSearch.Click();
- var caseLink = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.XPath($"//a[normalize-space()='{caseNo.Trim()}']"));
- }
- catch
- {
- return null;
- }
- });
- caseLink.Click();
- driver.SwitchTo().ParentFrame().SwitchTo().Frame(2);
- var DoItemLinks = wait.Until((d) => {
- return d.FindElements(By.XPath($"//td[@colname='ctrl_proc'][normalize-space()='{doItemName}']"));
- });
- if (DoItemLinks.Count > 0)
- {
- if (!string.IsNullOrEmpty(caseStage))
- {
- foreach (var DoItemLink in DoItemLinks)
- {
- var temCaseStage = DoItemLink.FindElement(By.XPath("following-sibling::td[1]")).Text;
- if (temCaseStage == caseStage)
- {
- retObject.CaseStage = DoItemLink.FindElement(By.XPath("following-sibling::td[1]")).Text; //案件阶段
- retObject.DoItemState = DoItemLink.FindElement(By.XPath("following-sibling::td[2]")).Text; //处理事项处理状态
- retObject.InternalDate = DoItemLink.FindElement(By.XPath("following-sibling::td[4]")).Text; //内部期限
- retObject.CustomerLimitDate = DoItemLink.FindElement(By.XPath("following-sibling::td[5]")).Text; //客户期限
- retObject.FinishedDate = DoItemLink.FindElement(By.XPath("following-sibling::td[7]")).Text; //处理事项完成日
- retObject.DoPersons = DoItemLink.FindElement(By.XPath("following-sibling::td[8]")).Text; //处理人
- retObject.ExternalHandler = DoItemLink.FindElement(By.XPath("following-sibling::td[9]")).Text; //对外处理人
- retObject.Reviewer = DoItemLink.FindElement(By.XPath("following-sibling::td[10]")).Text; //核稿人
- retObject.DoItemMemo = DoItemLink.FindElement(By.XPath("following-sibling::td[12]")).Text; //处理事项备注
- DoItemLink.Click();
- break;
- }
- }
- }
- else
- {
- var DoItemLink = DoItemLinks[DoItemLinks.Count - 1];
- retObject.CaseStage = DoItemLink.FindElement(By.XPath("following-sibling::td[1]")).Text; //案件阶段
- retObject.DoItemState = DoItemLink.FindElement(By.XPath("following-sibling::td[2]")).Text; //处理事项处理状态
- retObject.InternalDate = DoItemLink.FindElement(By.XPath("following-sibling::td[4]")).Text; //内部期限
- retObject.CustomerLimitDate = DoItemLink.FindElement(By.XPath("following-sibling::td[5]")).Text; //客户期限
- retObject.FinishedDate = DoItemLink.FindElement(By.XPath("following-sibling::td[7]")).Text; //处理事项完成日
- retObject.DoPersons = DoItemLink.FindElement(By.XPath("following-sibling::td[8]")).Text; //处理人
- retObject.ExternalHandler = DoItemLink.FindElement(By.XPath("following-sibling::td[9]")).Text; //对外处理人
-
- retObject.Reviewer = DoItemLink.FindElement(By.XPath("following-sibling::td[10]")).Text; //核稿人
- retObject.DoItemMemo = DoItemLink.FindElement(By.XPath("following-sibling::td[12]")).Text; //处理事项备注
- DoItemLink.Click();
-
- }
- }
- var p_proc_finish_doc_date = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.Id("p_proc_info__finish_doc_date"));
- }
- catch
- {
- return null;
- }
- });
- retObject.FinalizationDate = p_proc_finish_doc_date.GetAttribute("value"); //定稿日
- retObject.ReturnDate = driver.FindElement(By.Id("p_proc_info__back_date")).GetAttribute("value"); //返稿日
- retObject.Reviewer = driver.FindElement(By.Id("p_proc_info__revise_user")).GetAttribute("value"); //核稿人
- retObject.DoItemCoefficient = driver.FindElement(By.Id("p_proc_info__proc_coefficient")).GetAttribute("value"); //处理事项系数
- retObject.WordCount = driver.FindElement(By.Id("p_proc_info__translate_count")).GetAttribute("value"); //翻译字数
- waitGetElementById(wait, "libase").Click();
- var p_case_info__case_name = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.Id("p_case_info__case_name"));
- }
- catch
- {
- return null;
- }
- });
- retObject.CaseName = p_case_info__case_name.GetAttribute("value"); //案件名称
- retObject.CustomerName = driver.FindElement(By.Id("p_case_info__customer_id")).GetAttribute("value").Replace("(null)",""); //客户名称
- retObject.BusinessType = driver.FindElement(By.Id("p_case_info__business_type_id")).GetAttribute("value"); //业务类型
- retObject.CaseState = GetSelectText(driver.FindElement(By.Id("p_case_info__case_status_id")));
- retObject.ApplicationType = GetSelectText(driver.FindElement(By.Id("p_case_info__apply_type_id")));
- retObject.CaseType = driver.FindElement(By.Id("p_case_info__case_type_id")).GetAttribute("value"); //案件类型
- retObject.EntrustingDate = driver.FindElement(By.Id("p_case_info__charge_date")).GetAttribute("value"); //委案日期
- retObject.CaseMemo = driver.FindElement(By.Id("p_case_info__remark")).GetAttribute("value"); //案件备注
- driver.FindElement(By.XPath($"//span[contains(text(),'扩展信息')]")).Click();
- retObject.CaseCoefficient = GetSelectText(driver.FindElement(By.Id("p_case_info__case_coefficient_id")));
-
- }
- catch (Exception ex)
- {
- throw new Exception(ex.Message, ex);
- }
- finally
- {
- driver.Quit();
-
- killChromProcess();
- }
- }
- Service.Dispose();
- }
- return retObject;
- }
- private static dynamic GetAPCNPerformanceRecord(string caseNo, string doItemName, string caseStage = null)
- {
- dynamic retObject = new ExpandoObject();
- retObject.CaseNo = caseNo.Trim();
- retObject.DoItem = doItemName;
- using (var Service = ChromeDriverService.CreateDefaultService(ConfigHelper.GetSectionValue("IPEasySetting:ChormeDriverPath")))
- {
- Service.Start();
- using (IWebDriver driver = CreateChromeDriver())
- {
- try
- {
- WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(10));
- Login(driver, wait);
- //点击顶部菜单栏中的案件管理菜单
- driver.FindElement(By.Name("71A7CC35-F597-40E1-9FEF-BE622A3A3B63")).Click();
- System.Threading.Thread.Sleep(500);
- //点击左侧 查询 菜单
- driver.FindElement(By.Name("FF4E1FF9-FE36-4F0F-99DF-81E60817722E")).Click();
- driver.SwitchTo().Frame(1);
- var inputSearch = wait.Until((d) =>
- {
- try
- {
- //切换到自定义报表Frame
-
- return d.FindElement(By.Id("case_volume"));
- }
- catch
- {
- return null;
- }
- });
-
- inputSearch.SendKeys(caseNo.Trim());
- var btnSearch = waitGetElementById(wait,"btn_Search");
- btnSearch.Click();
- var caseLink = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.XPath($"//a[normalize-space()='{caseNo.Trim()}']"));
- }
- catch
- {
- return null;
- }
- });
- caseLink.Click();
- driver.SwitchTo().ParentFrame().SwitchTo().Frame(2);
- var DoItemLinks = wait.Until((d) => {
- return driver.FindElements(By.XPath($"//td[@colname='ctrl_proc'][normalize-space()='{doItemName}']"));
- });
- if (DoItemLinks.Count > 0)
- {
- if (!string.IsNullOrEmpty(caseStage))
- {
- foreach (var DoItemLink in DoItemLinks)
- {
- var temCaseStage = wait.Until((d) => {
- return DoItemLink.FindElement(By.XPath("following-sibling::td[1]"));
- }).Text;
- if (temCaseStage == caseStage)
- {
- retObject.DoItemState = DoItemLink.FindElement(By.XPath("following-sibling::td[1]")).Text; //处理事项处理状态
- retObject.InternalDate = DoItemLink.FindElement(By.XPath("following-sibling::td[3]")).Text; //内部期限
- retObject.CustomerLimitDate = DoItemLink.FindElement(By.XPath("following-sibling::td[4]")).Text; //客户期限
- retObject.FinishedDate = DoItemLink.FindElement(By.XPath("following-sibling::td[6]")).Text; //处理事项完成日
- retObject.DoPersons = DoItemLink.FindElement(By.XPath("following-sibling::td[7]")).Text; //处理人
- retObject.DoItemMemo = DoItemLink.FindElement(By.XPath("following-sibling::td[10]")).Text; //处理事项备注
- DoItemLink.Click();
- //driver.ExecuteJavaScript("$(arguments[0]).click()", DoItemLink);
- break;
- }
- }
- }
- else
- {
- var DoItemLink = DoItemLinks[DoItemLinks.Count - 1];
- //retObject.CaseStage = DoItemLink.FindElement(By.XPath("following-sibling::td[1]")).Text; //案件阶段
- retObject.DoItemState = DoItemLink.FindElement(By.XPath("following-sibling::td[1]")).Text; //处理事项处理状态
- retObject.InternalDate = DoItemLink.FindElement(By.XPath("following-sibling::td[3]")).Text; //内部期限
- retObject.CustomerLimitDate = DoItemLink.FindElement(By.XPath("following-sibling::td[4]")).Text; //客户期限
- retObject.FinishedDate = DoItemLink.FindElement(By.XPath("following-sibling::td[6]")).Text; //处理事项完成日
- retObject.DoPersons = DoItemLink.FindElement(By.XPath("following-sibling::td[7]")).Text; //处理人
- retObject.DoItemMemo = DoItemLink.FindElement(By.XPath("following-sibling::td[10]")).Text; //处理事项备注
- //retObject.Reviewer = DoItemLink.FindElement(By.XPath("following-sibling::td[10]")).Text; //核稿人
- DoItemLink.Click();
- //new WebDriverWait(driver, TimeSpan.FromSeconds(20)).Until(ExpectedConditions.ElementToBeClickable(DoItemLink)).Click();
- }
- }
- var p_proc_finish_doc_date = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.Id("p_proc_info__finish_doc_date"));
- }
- catch
- {
- return null;
- }
- });
- //System.Threading.Thread.Sleep(500);
- retObject.FinalizationDate = p_proc_finish_doc_date.GetAttribute("value"); //定稿日
- retObject.ReturnDate = driver.FindElement(By.Id("p_proc_info__back_date")).GetAttribute("value"); //返稿日
- retObject.Reviewer = driver.FindElement(By.Id("p_proc_info__revise_user")).GetAttribute("value"); //核稿人
- retObject.DoItemCoefficient = driver.FindElement(By.Id("p_proc_info__proc_coefficient")).GetAttribute("value"); //处理事项系数
- retObject.WordCount = driver.FindElement(By.Id("p_proc_info__translate_count")).GetAttribute("value"); //翻译字数
- waitGetElementById(wait,"libase").Click();
- var p_case_info__case_name = wait.Until((d) =>
- {
- try
- {
- return d.FindElement(By.Id("p_case_info__case_name"));
- }
- catch
- {
- return null;
- }
- });
- //System.Threading.Thread.Sleep(500);
- retObject.CaseName = p_case_info__case_name.GetAttribute("value"); //案件名称
- retObject.CustomerName = driver.FindElement(By.Id("p_case_info__customer_id")).GetAttribute("value"); //客户名称
- retObject.BusinessType = driver.FindElement(By.Id("p_case_info__business_type_id")).GetAttribute("value"); //业务类型
- retObject.CaseState = GetSelectText(driver.FindElement(By.Id("p_case_info__case_status_id")));
- retObject.ApplicationType = GetSelectText(driver.FindElement(By.Id("p_case_info__apply_type_id")));
- retObject.CaseType = driver.FindElement(By.Id("p_case_info__case_type_id")).GetAttribute("value"); //案件类型
- retObject.EntrustingDate = driver.FindElement(By.Id("p_case_info__charge_date")).GetAttribute("value"); //委案日期
- retObject.CaseMemo = driver.FindElement(By.Id("p_case_info__remark")).GetAttribute("value"); //案件备注
- //driver.FindElement(By.XPath($"//span[contains(text(),'扩展信息')]")).Click();
- //select[@id='p_case_info__case_coefficient_id']
- //retObject.CaseCoefficient = GetSelectText(driver.FindElement(By.Id("p_case_info__case_coefficient_id")));
- }
- catch (Exception ex)
- {
- throw new Exception(ex.Message, ex);
- }
- finally
- {
- driver.Quit();
- killChromProcess();
- }
- }
- Service.Dispose();
- }
- return retObject;
- }
- private static void killChromProcess()
- {
- try
- {
- Process[] workers = Process.GetProcessesByName("Chrome");
- foreach (Process worker in workers)
- {
- worker.Kill();
- worker.WaitForExit();
- worker.Dispose();
- }
- workers = Process.GetProcessesByName("Chromedriver");
- foreach (Process worker in workers)
- {
- worker.Kill();
- worker.WaitForExit();
- worker.Dispose();
- }
- }
- catch { }
- }
- private static string GetSelectText(IWebElement element)
- {
- var strValue = element.GetAttribute("value");
- if (string.IsNullOrEmpty(strValue))
- {
- return null;
- }
- var ops = element.FindElements(By.TagName("option"));
- foreach (var op in ops)
- {
- if (op.GetAttribute("value") == strValue)
- {
- return op.Text;
- }
- }
- return null;
- }
- }
- }
|