Skip to content

The course site for the Data Processing in Python from IES

Notifications You must be signed in to change notification settings

TentoSipka/PythonDataIES

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Data Processing in Python (JEM207)

The course site for the Data Processing in Python from IES. See information on SIS. The course is taught by Martin Hronec and Jan Šíla.

Course syllabus

Date Topic who Project HW
18/2 Intro, Jupyter, Git (+ GitHub) Martin
25/2 Strings, Floats, Lists, Dictionaries, Functions Jan HW 0 & 1
3/3 Numpy, Pandas, Matplotlib Martin HW 2
10/3 Object-Oriented Programming Martin HW 3
17/3 HTML, XML, JSON, requests, APIs, BeautifulSoup Jan
24/3 IES Web Scraper Jan HW 4
31/3 Advanced Pandas Martin Project Topic Proposal HW 5
7/4 MIDTERM both
14/4 Introduction to Databases Jan Project Topic Approval HW 6
21/4 Project Work 1 both Work-in-progress
28/4 Guest Lecture + Beer MeetUp TBD
5/5 Efficient Computing / Parallelization Martin
12/5 Project Work 2 Both Work-in-progress

Course requirements

The requirements for passing the course are DataCamp assignments (5pts), the midterm (25pts), work in-progress-presentation (5pts), and the final project - including the final delivery presentation (65pts). At least 50% from the DataCamp assignments and work-in-progress presentation is required for passing the course.

Final project (65%)

  • Students in teams by 2
  • The task is to download any data from API or directly from the web. These data should be processed and visualized in the Jupyter Notebook, with auxiliary scripts consisting of functions and classes definitions as .py files. The project should be submitted as a GitHub repository.
  • The selection of the data is up to the students. (Conditional on our approval.)
  • Git collaboration as a proof of collaboration of both students.
  • More details during the lecture.

See example projects from the previous semesters here or here from last year.

Project work - presentation (5%)

  • Presentation of work-in-progress related to the final project (during the lectures "Project work 1 or 2" on 21/4 or 12/5)

Midterm exam (25%)

4th of April. Live coding (80 minutes), "open browser", no collaboration between the students. More details during the lecture week before

DataCamp Assignments (5%)

3 assignments out of assignments 1-6 submitted on time is required.

Assignment 0 - Submission on 25/2 (Introduction to Git)

  • Compulsory. Git is hard and you will need it throughout the course.

Assignment 1 - Submission on 25/2 (Introduction to Python Course)

  1. Python Lists
  2. Python Basics
  3. Function and Packages

Assignment 2 - Submission on 3/3 (Manipulating DataFrames with pandas)

  1. Numpy
  2. Extracting and Transforming Data
  3. Advanced Indexing

Assignment 3 - Submission on 10/3 (Object-Oriented Programming in Python)

  1. Getting ready for object-oriented programming
  2. Deep dive into classes and objects
  3. Fancy classes, fancy objects

Assignment 4 - Submission on 24/3 (Web Scraping in Python Course)

  1. Introduction to HTML
  2. XPaths and Selectors
  3. CSS Locators, Chaining, and Responses

Assignment 5 - Submission on 31/3 (Merging DataFrames with pandas Course)

  1. Concatenating and merging data
  2. Rearranging and reshaping data
  3. Grouping data

Assignment 6 - Submission on 14/4 (Importing Data in Python (Part 2) Course)

  1. The Intro to SQL for Data Science (full course)

Recommended DataCamp Courses

Tools

Introduction to Git for Data Science

General Python

Introduction to Python

Intermediate Python for Data Science

pandas

pandas Foundations

Manipulating DataFrames with pandas

Merging DataFrames with pandas

Cleaning Data in Python

Web Data Formats

Importing Data in Python (Part 1)

Importing Data in Python (Part 2)

Web Scraping with Python

Data Visualizations

Introduction to Data Visualization

Interactive Data Visualization in Bokeh

SQL

Introduction to SQL for Data Science

Introduction to Databases in Python

Prerequisities

Econometrics II. (JEB110) is an explicit prerequisite for bachelor students.

The course is designed for students that have at least some basic coding experience. It does not need to be very advanced, but they should be aware of concepts such as for loop ,if and else,variable or function.

No knowledge of Python is required for entering the course.

Credits

Passing the course is rewarded with 5 ECTS credits.

A sneak peek

IES web parser.

Materials

Git

Pro Git book, Atlassian Git tutorials, Github resources for learning Git

Python

Resources from the official Python webpage

Documentations

Python, Pandas, Numpy, requests, BeautifulSoup and Matplotlib.

About

The course site for the Data Processing in Python from IES

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 85.0%
  • Jupyter Notebook 15.0%