There are lots of exciting and interesting problems in analytics, such as figuring out what the right question is, selecting features, training a model, and interpreting results. But all of that presupposes a tidy data set that is suitable for analysis or training models. Industry experts all agree that data collection and cleaning is roughly 3/4 of any analysis effort. This course teaches how to collect, coalesce, and clean data from multiple sources in preparation for your analysis work.
This course is part of the MS in Analytics program at the University of San Francisco.
INSTRUCTOR. Terence Parr. I’m a professor in the computer science department and was founding director of the MS in Analytics program at USF. Please call me Terence or Professor (the use of “Terry” is a capital offense).
SPATIAL COORDINATES. 101 Howard. Both sections Rm 527 on the fifth floor.
TEMPORAL COORDINATES. Wed Aug 24 - Wed Oct 12.
- Section 01: Mon/Wed 10-12AM
- Section 02: Mon/Wed 1-3PM
INSTRUCTION FORMAT. Class runs for 2 hours, 2 days. Instructor-student interaction during lecture is encouraged and we'll mix in mini-exercises / labs during class. All programming will be done in the Python programming language, unless otherwise specified.
TARDINESS. Please be on time for class. It is a big distraction if you come in late.
ACADEMIC HONESTY. You must abide by the copyright laws of the United States and academic honesty policies of USF. You may not copy code from other current or previous students. All suspicious activity will be investigated and, if warranted, passed to the Dean of Sciences for action. Copying answers or code from other students or sources during a quiz, exam, or for a project is a violation of the university’s honor code and will be treated as such. Plagiarism consists of copying material from any source and passing off that material as your own original work. Plagiarism is plagiarism: it does not matter if the source being copied is on the Internet, from a book or textbook, or from quizzes or problem sets written up by other students. Giving code or showing code to another student is also considered a violation.
The golden rule: You must never represent another person’s work as your own.
If you ever have questions about what constitutes plagiarism, cheating, or academic dishonesty in my course, please feel free to ask me.
Note: Leaving your laptop unattended is a common means for another student to take your work. It is your responsibility to guard your work. Do not leave your printouts laying around or in the trash. All persons with common code are likely to be considered at fault.
ON DISABILITIES. If you are a student with a disability or disabling condition, or if you think you may have a disability, please contact USF Student Disability Services (SDS) at 415/422-2613 within the first week of class, or immediately upon onset of the disability, to speak with a disability specialist. If you are determined eligible for reasonable accommodations, please meet with your disability specialist so they can arrange to have your accommodation letter sent to me, and we will discuss your needs for this course. For more information, please visit http://www.usfca.edu/sds/ or call 415/422-2613.
Artifact | Grade Weight | Due date |
---|---|---|
Data pipeline | 15% | Wed, Sep 7 before class |
Building web servers | 15% | Fri, Sep 16 midnight |
TFIDF document summarization | 15% | Mon, Sep 26 before class |
Group project | 30% | Wed, Oct 12 midnight |
Exam | 25% | 10AM-12PM Fri, Oct 14 |
All projects are graded in binary fashion: They either work or they do not, even if you just misspelled a function name. Each project has a hard deadline and only those projects working correctly before the deadline get credit (100%). My grading script pulls from github at the deadline. If you miss the deadline, you can still get 80% for the project if you complete it correctly by end of last class period.
Grading standards. I consider an A grade to be above and beyond what most students have achieved. A B grade is an average grade for a student or what you could call "competence" in a business setting. A C grade means that you either did not or could not put forth the effort to achieve competence. Below C implies you did very little work or had great difficulty with the class compared to other students.
- representing text in a computer; see also 7-bit ascii codes, unicode vs ascii in python
- Data pipeline project (Converting stock history from Yahoo finance to various formats) (project)
- reading delimited data; tsv, csv
- reading/generating XML (we'll load complicated XML in TFIDF project)
- reading/generating json
- PDF using pdf2txt.py (Parsing documents from Eisenhower's presidential library)
- Excel (Saving as CSV, stripping non-ASCII stuff, loading into Python)
- HTML (Parsing Tesla's IPO prospectus)
- Parsing web access log files
- Network sockets, DNS, email
- client/server architecture
- HTTP
- flask
- Web analytics
- Cookies, logging in/out
- Building web servers (project)
- files
- Pulling data from (open) REST APIs
- yahoo
- openpayments.us
- IMDB movie data
- Pull data from sites requiring an ID
- Zillow
- Youtube
- APIs requiring authentication/identification
- Extracting data from web pages
- Selenium
- Computing TFIDF
- TFIDF document summarization (project)
- regex
- Unix commands for extracting web content: wget, grep, awk, cut, paste, join, sed
- k-means for compression, color selection
- Running shell commands from Python
- San Francisco police incidents word clouds and heat maps