WIZ-AUTOEXPLORE01.ALT

This is an OutWit Tutorial file.


Testing Browser...
OutWit Hub Pro - Automatic Exploration
Application walkthrough: using exploration features
userSpace.setWizardPrefs = function setWizardPrefs(){ wizardKit.setWizardPref("browse.tempo.min", "1000"); wizardKit.setWizardPref("browse.tempo.max", "1000"); wizardKit.setWizardPref("applyScraper.tempo.min", "1000"); wizardKit.setWizardPref("applyScraper.tempo.max", "1000"); wizardKit.setWizardPref("images.ondemandonly", false); // witscript.setPreference("page.ignorePlugins", false); wizardKit.setWizardPref("page.ignoreImages", false); wizardKit.setWizardPref("tableMinRows", "1"); //alert(witscript.getPreference("DOMSourceDontWarn")); wizardKit.setWizardPref("DOMSourceDontWarn", true); //alert(witscript.getPreference("DOMSourceDontWarn")); }

So Many Ways to
Explore the World...


While this window is showing instructions, the user interface of OutWit Hub remains operational.

You can still interact normally with the application and you can move this tutorial window around on the screen to better see the parts of the interface that you want.

userSpace.eyeCatcherOK = !(wizardKit.platform=="mac" && /firefox/i.test(navigator.userAgent) && /rv:1[2-7]/i.test(navigator.userAgent)); if (/Firefox\/[23]\./.test(navigator.userAgent)){ alert("OutWit wizards cannot run on your version of Firefox. Please update to the current version and try again."); wizard.close(); } else if (!("witscript" in window) || !witscript.version || !witscript.version("3")){ alert("This wizard is not compatible with your version of the OutWit Kernel. Please download the latest version (2.0.1 or higher)"); wizard.close(); } if(witscript.version("3")){$(".owui-wizard-homelink").html("Hub Tutorials")}; wizardKit.hideCatch(); wizardKit.hideLog(); witscript.views.page.load("http://www.outwit.com/"); //userSpace.storeOriginalPrefs(); userSpace.setWizardPrefs(); witscript.logPanel.setAttribute("height",0);
wizardKit.say(this.parentNode); witscript.views.page.display();
wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); witscript.views.page.display(); witscript.menutree.focus();

The 5 main ways to auto-explore pages

1) Auto-browse series of results
2) Dig into a Website
3) Use grabbed or imported lists of URLs
4) Generate URLs
5) Build a self-navigating scraper

We are going to experiment all of these methods with you in the following pages.

The other important exploration function (fast-scraping) is covered in a separate tutorial.

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.page.display(); witscript.menutree.focus(); witscript.views.page.browser.scrollToPercent(0);

One Continent at a Time

Here is a page with a table of all African countries.
Let's simply grab this data with the 'tables' view.

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.tables.display(); witscript.views.tables.bottomPanel.pageLoad.empty.setValue(true); witscript.views.tables.bottomPanel.reapplyButton.click(); witscript.menutree.focus(); witscript.views.page.setAttribute("height",200) wizardKit.eyeCatcher(views.tables.bottomPanel.pageLoad.empty,2); witscript.wait(2000); wizardKit.eyeCatcher(views.tables.bottomPanel.pageLoad.empty); //wizardKit.eyeCatcher(views.words.bottomPanel.selectIf.textBox) witscript.wait(500); wizardKit.eyeCatcher(views.tables.bottomPanel.pageLoad.autoCatch);

Done. Now we can do this for the whole world... But before, we need to make sure we will not loose our data.
For this we can either keep the extracted data in the tables view by choosing Empty on Demand, or move it to the Catch by selecting Auto-Catch.

(Do not do both or you will send masses of redundant data to the catch at each page load.)

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.tables.display(); witscript.wait(1000); witscript.views.tables.bottomPanel.pageLoad.empty.setValue(true); witscript.views.tables.bottomPanel.reapplyButton.click(); witscript.views.tables.bottomPanel.pageLoad.empty.setValue(false); witscript.views.tables.bottomPanel.pageLoad.autoCatch.setValue(false); wizardKit.eyeCatcher(views.tables.bottomPanel.pageLoad.empty);

Let's disable 'Auto-Empty' and keep the data in tables.

wizardKit.say(this.parentNode); //views.tables.exportPreview.setAttribute("width",100) witscript.views.tables.previewSplitter.collapseAfter() //views.tables.exportPreview.exportType.setValue("excel") witscript.views.tables.display(); witscript.menutree.focus(); wizardKit.eyeCatcher(witscript.toolbar.outwitIcons,1,1,-10);

1) Auto-Browsing

We are ready.
As there is a nice simple Next Page link in our web page, OutWit couldn't miss it, and we just need to click on the next button (single right arrow) to go to the next page or on the Browse button (double right arrow) to go through all pages.

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.tables.display(); witscript.wait(1000); wizardKit.eyeCatcher(witscript.toolbar.outwitIcons,1,1,-10); witscript.views.tables.bottomPanel.pageLoad.empty.setValue(true); witscript.views.tables.bottomPanel.reapplyButton.click(); witscript.views.tables.bottomPanel.pageLoad.empty.setValue(false); witscript.toolbar.outwitIcons.browse.next10Pages.click();

Let's click on browse.

The program is now loading all the pages of the series, until no more Next Page link is found.

Once we have reached Oceania, all countries will have been collected in the tables view.
(Note that if you are running the light version of OutWit Hub, the number of extracted rows is limited to 100, so you will not see all.)

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.page.display(); witscript.views.tables.bottomPanel.pageLoad.empty.setValue(true); //toolbar.outwitIcons.dig

2) The Dig Function

'Browse' was the first exploration tool. It is mostly useful for search engine or database result pages, with a succession of pages to be explored. OutWit does its best to find the link from one page to the other (and succeeds in most cases).

Let's now try another way: Digging the links, with a filter.

Digging (Navigation>Dig menu or double down arrow) means exploring the links of a page at a given depth, possibly with a filter criterion.

If you did a Dig without any limitations, the program would go from page to page, adding every link it finds to a queue to later explore that page, get more links, and so on... It would basically explore the Internet.
We don't want to do that.

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.page.display();

We only wish to explore the six continent pages again (with URLs containing the string "countries/ow-explore"). Let's use this string to limit the exploration.
Here is the Advanced Settings dialog you get from the navigation menu:

(Note that Dig's Advanced Settings are a pro-only feature.)

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.page.display();

The pages of this example do not contain outside links, so you can play with the dig function with or without filters, it will remain within the list of countries. Once you are done, we will see other ways to do this...

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.tables.display(); witscript.views.page.setAttribute("height",200) witscript.views.tables.bottomPanel.pageLoad.empty.setValue(true); witscript.views.tables.bottomPanel.reapplyButton.click(); witscript.views.tables.datasheet.selectRows([4,8,9,10,14,15,18,19,20]); witscript.views.tables.datasheet.focus();

3) Exploring lists of URLs

Another way to proceed is to select the list of URLs you want to visit, in any datasheet of the application (or in a directory of the queries view)...

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.tables.display(); witscript.views.page.setAttribute("height",200) witscript.views.tables.bottomPanel.pageLoad.empty.setValue(true); witscript.views.tables.bottomPanel.reapplyButton.click(); witscript.views.tables.datasheet.selectRows([4,8,9,10,14,15,18,19,20]); witscript.views.tables.datasheet.focus(); //views.tables.datasheet.clickCell(4,3,"right"); witscript.views.tables.datasheet.contextMenu.autoExplore.click();


Then right-click on one of the selected links and choose Auto-Explore, then Browse, Dig or Fast Scrape. Do this with a bunch of links.

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.page.display();

4) Exploring generated URLs

If the links you want to explore are built on a logical format and if they are not conveniently gathered in a single page, the easiest is often to ask OutWit to generate them.

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/country/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/country_024.html"); } var currentAutomator = views.queries.manager.currentAutomator(); if (!userSpace.queryName || userSpace.queryName != currentAutomator.name) { for (var i=0;i<views.queries.manager.datasheet.getRowCount();i++){ if(/Tutorial Query/.test(views.queries.manager.datasheet.getCell(i,3))) { witscript.views.queries.editor.display(); witscript.views.queries.editor.datasheet.focus(); witscript.views.queries.editor.datasheet.select(i); witscript.views.queries.manager.deleteSelectedAutomator(true); break; } } witscript.views.queries.manager.createAutomator("Tutorial Query"); currentAutomator = views.queries.manager.currentAutomator(); userSpace.queryName = currentAutomator.name; } witscript.views.queries.display(); witscript.views.queries.editor.datasheet.focus(); // doesn't work: //views.queries.editor.datasheet.contextMenu.insertMenu.insertRow.click(); if(!views.queries.editor.datasheet.getRowCount()) { witscript.views.queries.editor.datasheet.insertRow(); //views.queries.editor.datasheet.clickCell("left",0,4); witscript.views.queries.editor.datasheet.setCellValue(0, 4, "http://www.outwit.com/support/help/hub/tutorials/work/countries/country_[001:194].html"); // doesn't work: //views.queries.editor.datasheet.contextMenu.insertMenu.insertRows.click(); //views.queries.editor.datasheet.clickCell(0,4,"left",true); } witscript.views.queries.manager.resize("width", null, 200,100,false) witscript.views.queries.editor.datasheet.headers.QueryString.setAttribute("width", "530"); witscript.wait(1000); wizardKit.eyeCatcher(views.queries.editor.datasheet.headers.QueryString,1,3,0,0);

OutWit's Query Generation Patterns

You may have noticed already that all country pages file names are in the same format: country_XXX.html. In such cases, you can generate the URLs to explore. A simple format allows you to do this easily in OutWit Hub.

In this pattern we have simply replaced the number by the range [001:194] in the URL. If you right-click on it and choose 'insert rows', it will generate strings in the directory. If you right-click on it and choose Browse or Dig in the Auto-Explore submenu, it will load all the pages one by one... Finally, you can use it in a macro, apply a scraper on all the URLs it generates, etc.

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); } witscript.views.page.display();

5) Self-Navigating Scrapers

We have learned about the 'Browse' and 'Dig' functions, used them on a page, on a list of URLs or on a URL generation pattern, we could have also done a fast scrape on these pages but 'Fast Scraping' is the subject of a separate tutorial. (You should refer to it after this one).

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/ow-explore-africa.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-africa.html"); }

Navigation directives

The final function we will experiment with involves scraper advanced features. This is often the last resort if no simple and logical naming format can be found or if the list of URLs is too difficult to collect: include the navigation within a scraper.

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/country_003.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/country_003.html"); } witscript.wait(500); witscript.views.scrapers.display(); var currentAutomator = views.scrapers.manager.currentAutomator(); if (currentAutomator && currentAutomator.automatorId == -1) { witscript.views.scrapers.editor.manageButton.click(); } var currentAutomator = views.scrapers.manager.currentAutomator(); if (!userSpace.scraperName || userSpace.scraperName != currentAutomator.name) { for (var i=0;i<views.scrapers.manager.datasheet.getRowCount();i++){ if(/Tutorial Self\-Navigating/.test(views.scrapers.manager.datasheet.getCell(i,3))) { witscript.views.scrapers.editor.display(); witscript.views.scrapers.editor.datasheet.focus(); witscript.views.scrapers.editor.datasheet.select(i); witscript.views.scrapers.manager.deleteSelectedAutomator(true); break; } } witscript.views.scrapers.manager.createAutomator("Tutorial Self-Navigating Scraper"); currentAutomator = views.scrapers.manager.currentAutomator(); userSpace.scraperName = currentAutomator.name; } witscript.wait(1000,function(){return views.scrapers.source.isLoaded();}); witscript.wait(300); witscript.views.scrapers.editor.sourceSelector.static.click(); witscript.views.scrapers.editor.display(); witscript.wait(100); witscript.views.scrapers.editor.datasheet.focus(); witscript.wait(100); witscript.views.scrapers.source.scrollToPercent(.4); witscript.wait(100); witscript.views.scrapers.source.findBar.toggleHighlight(false); witscript.views.scrapers.source.findBar.toggleHighlight(true, "/(Internet Tld:.+?</td>|name:.+?</td>)/gi"); witscript.wait(100); witscript.views.scrapers.editor.datasheet.setCellValue(0, 1, true); witscript.views.scrapers.editor.datasheet.setCellValue(0, 2, "name"); witscript.views.scrapers.editor.datasheet.setCellValue(0, 3, "name:</td>"); witscript.views.scrapers.editor.datasheet.setCellValue(0, 4, "</td>"); witscript.views.scrapers.editor.datasheet.setCellValue(1, 1, true); witscript.views.scrapers.editor.datasheet.setCellValue(1, 2, "code"); witscript.views.scrapers.editor.datasheet.setCellValue(1, 3, "Internet Tld:</td>"); witscript.views.scrapers.editor.datasheet.setCellValue(1, 4, "</td>"); witscript.menutree.focus();

Let's make a little scraper to grab the country name and its international two-letter code. We will then give it the ability to navigate alone within the pages.

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/country_003.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/country_003.html"); } witscript.views.scrapers.editor.display(); witscript.views.scrapers.editor.url.setValue("tutorials/work/countries/"); wizardKit.eyeCatcher(views.scrapers.editor.url,1,1,0,0);

5) Self-Navigating Scrapers

Let's make sure our scraper doesn't only apply to country pages (URLs containing "country_"), but also to list pages: It must apply to URLs containing "tutorials/work/countries". (In other cases you may have to create several scrapers.)

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/country_003.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/country_003.html"); } witscript.wait(1000,function(){return views.scrapers.source.isLoaded();}); witscript.wait(300); witscript.views.scrapers.editor.sourceSelector.static.click() witscript.views.scrapers.editor.display(); witscript.wait(100); witscript.views.scrapers.editor.datasheet.focus(); witscript.wait(100); witscript.views.scrapers.source.scrollToPercent(.4); witscript.wait(100); witscript.views.scrapers.source.findBar.toggleHighlight(false); witscript.wait(100); witscript.views.scrapers.editor.datasheet.select(2); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 2, 1, true); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 2, 2, "#nextPage#0#"); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 2, 6, "#BACK#");

Then, let's add a #nextPage# directive for the country pages, and set it to #BACK# so that after scraping a country, the program backtracks to the list. We put #nextPage#0# so that, with the lowest rating, this scraper line is only applied if no other next page link is found.

wizardKit.say(this.parentNode); wizardKit.hideCatch(); wizardKit.hideLog(); if(!(/work\/countries\/country_003.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/country_003.html"); } witscript.wait(1000,function(){return views.scrapers.source.isLoaded();}); witscript.wait(300); witscript.views.scrapers.editor.sourceSelector.static.click() witscript.views.scrapers.editor.display(); witscript.wait(100); witscript.views.scrapers.editor.datasheet.focus(); witscript.wait(100); witscript.views.scrapers.source.scrollToPercent(.4); witscript.wait(100); witscript.views.scrapers.source.findBar.toggleHighlight(false); witscript.wait(100); witscript.views.scrapers.editor.datasheet.select(2); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 3, 1, true); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 3, 2, "#nextPage#2#"); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 3, 3, '<a href="'); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 3, 4, '">Next \x26gt;</a>'); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 3, 6, '#BASEURL#\\0'); witscript.wait(600); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 4, 1, true); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 4, 2, "#addToQueue#"); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 4, 3, '<td class="c3"><a href="'); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 4, 4, '"'); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 4, 6, '#BASEURL#\\0'); witscript.wait(1500); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 5, 1, true); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 5, 2, "#nextPage#3#"); wizardKit.typeCellValue(witscript.views.scrapers.editor.datasheet, 5, 6, '#nextToVisit()#;');

When on a page with a list of countries, line 4 will grab the next page and line 5 will add country URLs to the queue to be explored.
Line 6 tells outwit to explore the URLs of the queue one after another (with the highest priority.)

wizardKit.say(this.parentNode); wizardKit.hideCatch(); if(!(/work\/countries\/ow-explore-continents.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-continents.html"); } wizardKit.showLog(0); witscript.views.page.setAttribute("height",200); witscript.menutree.focus(); witscript.views.scraped.bottomPanel.pageLoad.empty.setValue(true); witscript.views.scraped.datasheet.contextMenu.selectMenu.selectAll.click(); witscript.views.scraped.datasheet.contextMenu.deleteMenu.delete.click();

Now, we just need to go to the top page: list of continents, keep the data in the scraped view (by unchecking 'empty')...

wizardKit.say(this.parentNode); wizardKit.hideCatch(); if(!(/work\/countries\/ow-explore-continents.html/.test(witscript.toolbar.urlBar.getValue()))){ witscript.views.page.load("http://www.outwit.com/support/help/hub/tutorials/work/countries/ow-explore-continents.html"); } witscript.views.scrapers.editor.executeButton.click(); wizardKit.showLog(0); witscript.views.page.setAttribute("height",200); witscript.menutree.focus(); witscript.wait(500); witscript.views.scraped.datasheet.contextMenu.selectMenu.selectAll.click(); witscript.views.scraped.datasheet.contextMenu.deleteMenu.delete.click(); witscript.views.scraped.bottomPanel.pageLoad.empty.setValue(false); witscript.wait(500); witscript.toolbar.outwitIcons.browse.next20Pages.click(); witscript.views.scraped.bottomPanel.pageLoad.empty.setValue(false);

...and click on browse.
The program first visits all the list pages storing the URLs to explore in the queue, thanks to the #addToQueue# directive, it will then grab the data from coutry pages.
(To be kind to our servers and your patience, we are only exploring the first pages, so you will have data for a handful of countries, but you got the point).

wizardKit.say(this.parentNode); witscript.menutree.focus(); if(witscript.version("2.1")){$(".owui-wizard-homelink").attr("style","color: #DFFFF9 !important; float:left;").html("More Tutorials")};

Our Tutorial is Over
(Your turn now.)

Auto-Browsing through series of pages, Digging down the hierarchy of a site, combining both, exploring lists of URLs or automatically generated URLs, fast scraping... all these functions are described in the Help. The basic features of OutWit Hub are as simple as a click or two. When confronted with complex cases, though, choosing the most appropriate option can make you save hours or even days...

Click on help for help