Website Scraping with Python
Website Scraping with Python
How to use BeautifulSoup and Scrapy in practice
About the Book
New version by Apress
In 2018 I teamed-up with Apress and we released an updated version of this book. You can find it on Amazon: https://amzn.to/2Dkl4gI
This book is the follow-up of my previous one: "XML processing and website scraping in Java". There I looked at ways and tools to process XML and HTML in Java, did some performace comparisons and introduced some new programming concepts to make things even better.
In this book I take a closer look at website scraping with the two tools used nowadays: BeautifulSoup and Scrapy.
I create the sample application from the Java book -- now in Python, use the two tools for parsing, show examples how to export CSV files in Python.
As a bonus I will compare the two tools for their runtime, try to tweak where possible and I will give a quick introduction on plotting the runtimes as charts.
Until it is finished, you can buy the book for a discounted price. The final book will be around $35.
I will write about the following topics in this book:
- Performance comparison
- Plotting in Python
- Functional programming with Python
- Parallel code execution with Python
- Sample application to gather Amazon data
- Other real-life projects (source code coming soon into the package)
- Update for Scrapy's release and Python 3 (coming soon)
- What will I do exactly?
- About the programming language
- Some extra feature
- Length of the book
- Some brief words about the project
1. BeautifulSoup – The ancestor of JSoup
- 1.1 Some words about BeautifulSoup
- 1.2 Configuring the download timeout
- 1.3 Configuring the proxy
- 1.4 Changing the XML-parser behind BeautifulSoup
- 1.5 Some of the errors that happened
- 1.6 Bits and pieces of the solution
- 1.7 Printing a CSV line
- 1.8 Conclusion
2. Scrapy – another way to gather data
- 2.1 Some words about Scrapy
- 2.2 Setting up the project
- 2.3 Configuring the download timeout
- 2.4 Configuring the proxy
- 2.5 Working with offline data
- 2.6 Bits and pieces of the solution
- 2.7 Errors which happened
- 2.8 Exporting the data as a CSV
- 2.9 Accessing settings
- 2.10 Scrapy as a library
- 2.11 Conclusion
3. Performance of the solutions
- 3.1 The dataset
- 3.2 Introducing the test environments
- 3.3 The test scenarios
- 3.4 BeautifulSoup compared with itself
- 3.5 Comparing Scrapy with itself
- 3.6 Comparing both tools
4. Creating plots with Python
- 4.1 Simple examples
- 4.2 Display multiple data ranges
- 4.3 Displaying the averages
- 4.4 Displaying the legend
- 4.5 Formatting the plot
- 4.6 Conclusion
5. Some thoughts on functional programming
- 5.1 The idea behind functional programming
- 5.2 First class functions
- 5.3 Currying
- 5.4 Writing declaratively
- 5.5 Using map and reduce
- 5.6 Using recursion
- 5.7 Pipelining
- 5.8 Applying functional programming
- 5.9 Conclusion
6. Parallel working
- 6.1 Why Should I care, I use Scrapy?
- 6.2 Parallelism in Python
- 6.3 An example
- 6.4 CPU-bound tasks
- 6.5 Possible errors you can encounter
- 6.6 Conclusion
- 6.7 Sources
7. Two real-life projects
- 7.1 Sport clubs spider
- 7.2 Bloso scraper
- 7.3 Conclusion
Extra! Extra! Read all about it!
- Introducing the requirements
- Starting the project
- The items
- Defining the spider
- Exporting the data into a database
- Offline data
- The sources
- Next step
Little Free Libraryhttp://www.littlefreelibrary.org
Our mission is to promote literacy and the love of reading by building free book exchanges worldwide and to build a sense of community as we share skills, creativity and wisdom across generations.
The Leanpub 45-day 100% Happiness Guarantee
Within 45 days of purchase you can get a 100% refund on any Leanpub purchase, in two clicks.
See full terms
Free Updates. DRM Free.
If you buy a Leanpub book, you get free updates for as long as the author updates the book! Many authors use Leanpub to publish their books in-progress, while they are writing them. All readers get free updates, regardless of when they bought the book or how much they paid (including free).
Most Leanpub books are available in PDF (for computers), EPUB (for phones and tablets) and MOBI (for Kindle). The formats that a book includes are shown at the top right corner of this page.
Finally, Leanpub books don't have any DRM copy-protection nonsense, so you can easily read them on any supported device.
El Manual del ManagerKeyvan Akbary, Félix López, and Álvaro Salazar
¿Has deseado alguna vez el haber tenido una buena introducción al rol del Engineering Manager? En este libro aprenderás lo necesario para ejercer el rol de una manera efectiva: Expectativas y Responsabilidades del Rol, 1-1s, Ayudar a Crecer, Objetivos, Planes de Carrera, Cultura, Feedback, Contratación, Cultura de Producto y mucho más.
Ansible for KubernetesJeff Geerling
Ansible is a powerful infrastructure automation tool. Kubernetes is a powerful application deployment platform. Learn how to use these tools to automate massively-scalable, highly-available infrastructure.
Functional Design and ArchitectureAlexander Granin
Software Design in Functional Programming, Design Patterns and Practices, Methodologies and Application Architectures. How to build real software in Haskell with less efforts and low risks. The first complete source of knowledge.
CCIE Service Provider Version 4 Written and Lab Exam Comprehensive GuideNicholas Russo
The service provider landscape has changed rapidly over the past several years. Networking vendors are continuing to propose new standards, techniques, and procedures for overcoming new challenges while concurrently reducing costs and delivering new services. Cisco has recently updated the CCIE Service Provider track to reflect these changes; this book represents the author's personal journey in achieving that certification.
CCIE SP v4.1 - WorkbookŁukasz Bromirski, Piotr Jablonski, and Nicholas Russo
Are you striving to prepare to and pass CCIE SP lab exam? Take the opportunity and get this workbook! With the attached initial cfg files you will prepare yourself for the CCIE SP exam as well as learn SP technologies applicable to all kinds of today modern networks! This workbook covers blueprint topics and provides challenging examples.
Ansible for DevOpsJeff Geerling
Ansible is a simple, but powerful, server and configuration management tool. Learn to use Ansible effectively, whether you manage one server—or thousands.
Code Faster in DelphiAlister Christie
This book will make you a faster Delphi developer, it doesn't matter if you are just starting out, or have been using Delphi since version 1, you will find all sorts of tips, tricks and hacks to boost your productivity.
R Programming for Data ScienceRoger D. Peng
This book brings the fundamentals of R programming to you, using the same material developed as part of the industry-leading Johns Hopkins Data Science Specialization. The skills taught in this book will lay the foundation for you to begin your journey learning data science. Printed copies of this book are available through Lulu.
Composing SoftwareEric Elliott
All software design is composition: the act of breaking complex problems down into smaller problems and composing those solutions. Most developers have a limited understanding of compositional techniques. It's time for that to change.
The Hundred-Page Machine Learning BookAndriy Burkov
Everything you really need to know in Machine Learning in a hundred pages.
11 BooksIn this bundle, you will find 10 different agile books. They are about different aspects of being agile. - finding a job - doing coding dojo's - Retrospectives - Personal kanban - a non-typical coaching book and even a book that gives you an insight in the lives of some agile people.
WTFlop 6M + HU - Beta Bundle
Fifty Quick Ideas
3 BooksGet all three books for the price of two! Fifty Quick Ideas books are full of practical, real-world techniques that you can use to improve teamwork, build better products and build them in a better way.
Growing Agile: Coach's Guide Series
4 BooksThis bundle provides a collection of training and workshop plans for a variety of agile topics. The series is aimed at agile coaches, trainers and ScrumMasters who often find themselves needing to help teams understand agile concepts. Each book in the series provides the plans, slides, handouts and activity instructions to run a number of...
Marionette.js A to Z
Build A Better Backbone App
3 BooksThe best way to learn new development skills is through experience, but that takes time you don't have.Get the best of both worlds with this bundle: you'll learn how to produce modern web applications by learning from experienced developers like Derick Bailey and David Sulc. BackboneJS is one of the favorite tools on the web today, but it...
People Skills—Soft but Difficult
7 BooksPerhaps you've been told that "lack of people skills" has been holding you back. No wonder: you may have had hundreds of hours of technical training, but little or no "people skills" guidance.You've heard it said that people skills are "soft," whereas technical skills are "hard." For you, though, technical skills are "easy," but people skills...
SurviveJS - Webpack + React
2 BooksGet both SurviveJS - Webpack and SurviveJS - React for a single price!
Experiential Learning Bundle
4 BooksThis bundle provides all four volumes of the popular Experiential Learning Series at a savings of $20 over the price if purchased separately.