export_to_xml(file_path, number, rows="", cols="", as_html=true, frame=-1); - экспорт таблицы с заданным номером или ее части в xml файл
file_path – путь к файлу. Путь к файлу может быть как полный (с указанием диска) так и относительный, в этом случае переданный путь будет добавлен к папке в которой находится php файл запущенного скрипта. number – номер по которому мы находим необходимый нам элемент на странице (int) . Номера элементов начинаются с 0 и для элементов разного типа своя нумерация. Чтобы узнать номер элемента, можно воспользоваться либо инспектором элементов, либо контекстным меню, либо посмотреть его в списке элементов.
rows – указывает с какими строками производить действие (string). Строки передаются в виде текста с номерами строк, разделенными запятой. Нумерация строк начинается с нуля. По умолчанию "" (все строки таблицы) . cols – указывает с какими столбцами производить действие (string). Столбцы передаются в виде текста с номерами столбцов, разделенными запятой. Нумерация столбцов начинается с нуля. По умолчанию "" (все строки таблицы) . as_html – сохранять текст ячеек как html (true), иначе как их внутренний текст (false) frame – номер фрейма, в котором мы ищем элемент (string). Номера фреймов начинаются с нуля. По умолчанию -1 - элемент находится не во фрейме. Номер фрейма в котором находится нужный вам элемент можно узнать из инспектора задач, контекстного меню и панели списка элементов.
С версии 4.6.41 доступно: можно передавать вложенные фреймы, принцип такой же самый, передается строка с номерами фреймов, разделенных : например при передаче "1:0:5" - будет выбран фрейм с номером 1 в нем под фрейм с номером 0 и в нем подфрейм с номером 5
С версии 7.0.38 доступно: можно передавать "url=>XXX", тогда будет произведен поиск фрейма, который содержит заданный src, или передавать "name=>XXX" - тогда будет поиск фрейма, по заданной части имени.
После отработки функция возвращает результат своей работы в робот (тип возвращаемого значения boolean):
true – выполнили успешно false – найти такой элемент не удалось (например нет вообще элементов, удовлетворяющих заданным критериям или нет такого фрейма)
Пример использования export_to_xml (PHP):
<?php $xhe_host = "127.0.0.1:7094"; // подключим объект для управления эмулятором, если еще не подключен if (!isset($path)) $path="../../../Templates/init.php"; require($path); // начало echo "<hr><font color=blue>table->".basename (__FILE__)."</font><hr>"; // 1 echo "1. Перейдем на полигон : "; echo $browser->navigate("http://rbot.biz-apps.ru/poligon/table.html")."<br>"; // 2 echo "2. Экспорт всей таблицы с 0 номером в xml как хтмл : "; echo $table->export_to_xml("c:\\1.xml",0)."<br>"; $app->shell_execute("open","c:\\1.xml","","c:\\",true); // 3 echo "3. Экспорт ячеек (1:1)(2:3)(6:2) таблицы с 0 номером в xml как текст : "; echo $table->export_to_xml("c:\\2.xml",0,"1,2,6","1,3,2",false)."<br>"; $app->shell_execute("open","c:\\2.xml","","c:\\",false); // 4 echo "3. Экспорт несуществующей таблицы в xml : "; if ($table->export_to_xml("c:\\0.xml",100500,"","",false)) echo "нет такого элемента<br>"; // 5 echo "5. Экспорт всей таблицы с 0 номером в csv как хтмл в нулевом фрейме : "; echo $table->export_to_xml("c:\\3.xml",0,"","",true,0)."<br>"; $app->shell_execute("open","c:\\3.xml","","c:\\",true); // 6 echo "6. Экспорт несуществующей таблицы в csv в нулевом фрейме : "; if ($table->export_to_xml("c:\\0.xml",100500,"","",false,0)) echo "нет такого элемента<br>"; // 7 echo "7. Экспорт таблицы в csv в несуществующем фрейме : "; if ($table->export_to_xml("c:\\0.xml",0,"","",false,5)) echo "нет такого фрейма<br>"; // конец echo "<hr><br>"; // Quit $app->quit(); ?>
Пример использования export_to_xml (C#):
#region using using System; using System.Diagnostics; using System.Collections.Generic; using System.Linq; using System.IO; using System.Text; using System.Threading; using XHE; using XHE.XHE_DOM; using XHE.XHE_System; using XHE.XHE_Window; using XHE.XHE_Web; #endregion class Program:XHEScript { static void Main(string[] args) { // init XHE server="127.0.0.1:7010"; InitXHE(); // начало echo("<hr><font color=blue>table.export_to_xml</font><hr>"); // 1 шаг echo("1. Перейдем на полигон : "); echo(browser.navigate("www.rbot.biz-apps.ru/poligon/table.html")+"<br>"); // 2 шаг echo("2. Экспорт всей таблицы с 0 номером в xml как хтмл : "); echo(table.export_to_xml("c:\\1.xml",0)+"<br>"); app.shell_execute("open","c:\\1.xml","","c:\\",1); // 3 шаг echo("3. Экспорт ячеек (1:1)(2:3)(6:2) таблицы с 0 номером в xml как текст : "); echo(table.export_to_xml("c:\\2.xml",0,"1,2,6","1,3,2",false)+"<br>"); app.shell_execute("open","c:\\2.xml","","c:\\",1); // 4 шаг echo("3. Экспорт несуществующей таблицы в xml : "); if (!table.export_to_xml("c:\\0.xml",100500,"","",false)) echo("нет такого элемента<br>"); // 5 шаг echo("5. Экспорт всей таблицы с 0 номером в csv как хтмл в нулевом фрейме : "); echo(table.export_to_xml("c:\\3.xml",0,"","",true,"0")+"<br>"); app.shell_execute("open","c:\\3.xml","","c:\\",1); // 6 шаг echo("6. Экспорт несуществующей таблицы в csv в нулевом фрейме : "); if (!table.export_to_xml("c:\\0.xml",100500,"","",false,"0")) echo("нет такого элемента<br>"); // 7 шаг echo("7. Экспорт таблицы в csv в несуществующем фрейме : "); if (!table.export_to_xml("c:\\0.xml",0,"","",false,"5")) echo("нет такого фрейма<br>"); // конец echo("<hr><br>"); app.quit(); } }
Пример использования export_to_xml (Python):
# Additional paths import sys sys.path.insert(0, '../../../Templates PY/') xhe_host = "127.0.0.1:7011" from xweb_human_emulator import * # начало echo("<hr><font color=blue>table.xxxxxxxxx</font><hr>") # 1 echo("1. Перейдем на полигон : ") echo(browser.navigate("http://www.rbot.biz-apps.ru/poligon/table.html"),"<br>") # 2 echo("2. Экспорт всей таблицы с 0 номером в xml как хтмл : ") echo(table.export_to_xml("c:\\1.xml",0),"<br>") app.shell_execute("open","c:\\1.xml","","c:\\",true) # 3 echo("3. Экспорт ячеек (1:1)(2:3)(6:2) таблицы с 0 номером в xml как текст : ") echo(table.export_to_xml("c:\\2.xml",0,"1,2,6","1,3,2",false),"<br>") app.shell_execute("open","c:\\2.xml","","c:\\",false) # 4 echo("3. Экспорт несуществующей таблицы в xml : ") if not table.export_to_xml("c:\\0.xml",100500,"","",false): echo("нет такого элемента<br>") # 5 echo("5. Экспорт всей таблицы с 0 номером в csv как хтмл в нулевом фрейме : ") echo(table.export_to_xml("c:\\3.xml",0,"","",true,0),"<br>") app.shell_execute("open","c:\\3.xml","","c:\\",true) # 6 echo("6. Экспорт несуществующей таблицы в csv в нулевом фрейме : ") if not table.export_to_xml("c:\\0.xml",100500,"","",false,0): echo("нет такого элемента<br>") # 7 echo("7. Экспорт таблицы в csv в несуществующем фрейме : ") if not table.export_to_xml("c:\\0.xml",0,"","",false,5): echo("нет такого фрейма<br>") # конец echo("<hr><br>") # Quit app.quit()
Пример использования export_to_xml (JS):
// подключим объект для управления эмулятором, если еще не подключен xhe_host="127.0.0.1:7010"; echo=require("../../../Templates JS/init.js"); // начало echo("<hr><font color=blue>table.export_to_xml</font><hr>"); // 1 шаг echo("1. Перейдем на полигон : "); echo(browser.navigate("http://www.rbot.biz-apps.ru/poligon/table.html")+"<br>"); // 2 шаг echo("2. Экспорт всей таблицы с 0 номером в xml как хтмл : "); echo(table.export_to_xml("c:\\1.xml",0)+"<br>"); app.shell_execute("open","c:\\1.xml","","c:\\",true); // 3 шаг echo("3. Экспорт ячеек (1:1)(2:3)(6:2) таблицы с 0 номером в xml как текст : "); echo(table.export_to_xml("c:\\2.xml",0,"1,2,6","1,3,2",false)+"<br>"); app.shell_execute("open","c:\\2.xml","","c:\\",false); // 4 шаг echo("4. Экспорт несуществующей таблицы в xml : "); if (!table.export_to_xml("c:\\0.xml",100500,"","",false)) echo("нет такого элемента<br>"); // 5 шаг echo("5. Экспорт всей таблицы с 0 номером в csv как хтмл в нулевом фрейме : "); echo(table.export_to_xml("c:\\3.xml",0,"","",true,0)+"<br>"); app.shell_execute("open","c:\\3.xml","","c:\\",true); // 6 шаг echo("6. Экспорт несуществующей таблицы в csv в нулевом фрейме : "); if (!table.export_to_xml("c:\\0.xml",100500,"","",false,0)) echo("нет такого элемента<br>"); // 7 шаг echo("7. Экспорт таблицы в csv в несуществующем фрейме : "); if (!table.export_to_xml("c:\\0.xml",0,"","",false,5)) echo("нет такого фрейма<br>"); // конец echo("<hr><br>"); // Quit app.quit();