Just developed a small crawler to check my online content at binfalse.de in terms of W3C validity and the availability of external links. Here is the code and some statistics…
The new year just started and I wanted to check what I produced the last year in my blog. Mainly I wanted to ensure more quality, my aim was to make sure all my blog content is W3C valid and all external resources I’m linking to are still available. First I thought about parsing the database-content, but at least I decided to check the real content as it is available to all of you. The easiest way to do something like this is doing it with Perl, at least for me. The following task were to do for each site of my blog:
- Check if W3C likes the site
- For each link to external resources: Check if they respond with
- For each internal link: Check this site too if not already checked
While I’m checking each site I also saved the number of leaving links to a file to get an overview. Here is the code:
You need to install
WebService::Validator::HTML::W3C . Sitting in front of a Debian based distribution just execute:
The script checks all sites that it can find and that match to
So adjust the
$domain variable at the start of the script to fit your needs.
It writes all W3C results to
/tmp/check-links.val , the following line-types may be found within that file:
So it should be easy to parse if you are searching for invalids.
Each external link that doesn’t answer with
200 OK produces an entry to
/tmp/check-links.fail with the form
Additionally it writes for each website the number of internal links and the number of external links to
If you want to try it on your site keep in mind to change the content of
$domain and take care of the pattern in line 65:
Because I don’t want to check internal links to files like
.tgz the URL has to end with
/ . All my sites containing parseable XML end with
/ , if your sites doesn’t, try to find a similar expression.
As I said I’ve looked to the results a bit. Here are some statistics (as at 2011/Jan/06):
|Sites containing W3C errors||38|
|Number of errors||63|
|Mean error per site||0.1309771|
|Mean of internal/external links per site||230.9833 / 15.39875|
|Median of internal/external links per site||216 / 15|
|Dead external links||82|
|Dead external links w/o Twitter||5|
Most of the errors are now repaired, the other ones are in progress.
The high number of links that aren’t working anymore comes from the little twitter buttons at the end of each article. My crawler is of course not authorized to tweet, so twitter responds with
401 Unauthorized . One of the other five fails because of a cert problem, all administrators of the other dead links are informed.
I also analyzed the outgoing links per site. I’ve clustered them with K-Means, the result can be seen in figure 1. How did I produce this graphic? Here is some R code:
You’re right, there is a lot stuff in the image that is not essential, but use it as example to show R beginners what is possible. Maybe you want to produce similar graphics!?
- analyzed (14) ,
- blog (16) ,
- clustering (4) ,
- gnu (22) ,
- media (57) ,
- network (66) ,
- private (25) ,
- programming (71)