Write a function build_csv_string(data) that takes in a list data. data will be a list of lists, where each sub list is of length 1, 2, or 3. Length 1 lists will contain a name (as a string). Length 2 lists will contain a name and an assignment title (as a string). Length 3 lists will contain a name, an assignment title, and a score (as a float or int). The function should return a valid csv string where each sublist is a record in the string. The header (first line) of the csv file should be 'name, assignment, grade\n'. Lists missing a grade value should use as the default, and missing assignment titles should be defaulted to 'N/A'

Computer Networking: A Top-Down Approach (7th Edition)
7th Edition
ISBN:9780133594140
Author:James Kurose, Keith Ross
Publisher:James Kurose, Keith Ross
Chapter1: Computer Networks And The Internet
Section: Chapter Questions
Problem R1RQ: What is the difference between a host and an end system? List several different types of end...
icon
Related questions
Question

In python

### Function Definition: build_csv_string(data)

This function, `build_csv_string(data)`, processes a list of lists, `data`, and converts it into a CSV string. The structure of each sublist is variable, where the length can be 1, 2, or 3, and each length has specific content requirements:

- **Length 1**: Includes only a name (as a string).
- **Length 2**: Includes a name and an assignment title (both as strings).
- **Length 3**: Includes a name, an assignment title, and a score (as either a float or an integer).

### Function Purpose

The function's goal is to return a CSV-formatted string where each sublist represents a record. The first line of the CSV string serves as a header and should be formatted as: `'name, assignment, grade\n'`.

### Handling Missing Data

- **Missing Grade**: Sublists that lack a grade should default the grade value to `0`.
- **Missing Assignment Title**: If the assignment title is missing, it should default to `'N/A'`.

Through this approach, the function ensures a consistent output format, handling any incomplete data by providing sensible defaults.
Transcribed Image Text:### Function Definition: build_csv_string(data) This function, `build_csv_string(data)`, processes a list of lists, `data`, and converts it into a CSV string. The structure of each sublist is variable, where the length can be 1, 2, or 3, and each length has specific content requirements: - **Length 1**: Includes only a name (as a string). - **Length 2**: Includes a name and an assignment title (both as strings). - **Length 3**: Includes a name, an assignment title, and a score (as either a float or an integer). ### Function Purpose The function's goal is to return a CSV-formatted string where each sublist represents a record. The first line of the CSV string serves as a header and should be formatted as: `'name, assignment, grade\n'`. ### Handling Missing Data - **Missing Grade**: Sublists that lack a grade should default the grade value to `0`. - **Missing Assignment Title**: If the assignment title is missing, it should default to `'N/A'`. Through this approach, the function ensures a consistent output format, handling any incomplete data by providing sensible defaults.
**Examples** (values in **bold** are returned):

```python
>>> build_csv_string([["Sam", "Lab 01", 5.4]])
'name,assignment,grade\nSam,Lab 01,5.4'
```

```python
>>> build_csv_string([["Sam", "Lab 01", 5.4], ["Zoe"]])
'name,assignment,grade\nSam,Lab 01,5.4\nZoe,N/A,0'
```

```python
>>> build_csv_string([["Sam", "Lab 01", 5.4], ["Zoe"], ["Amanda", "Quiz 04", 100]])
'name,assignment,grade\nSam,Lab 01,5.4\nZoe,N/A,0\nAmanda,Quiz 04,100'
```
Transcribed Image Text:**Examples** (values in **bold** are returned): ```python >>> build_csv_string([["Sam", "Lab 01", 5.4]]) 'name,assignment,grade\nSam,Lab 01,5.4' ``` ```python >>> build_csv_string([["Sam", "Lab 01", 5.4], ["Zoe"]]) 'name,assignment,grade\nSam,Lab 01,5.4\nZoe,N/A,0' ``` ```python >>> build_csv_string([["Sam", "Lab 01", 5.4], ["Zoe"], ["Amanda", "Quiz 04", 100]]) 'name,assignment,grade\nSam,Lab 01,5.4\nZoe,N/A,0\nAmanda,Quiz 04,100' ```
Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 3 steps with 2 images

Blurred answer
Recommended textbooks for you
Computer Networking: A Top-Down Approach (7th Edi…
Computer Networking: A Top-Down Approach (7th Edi…
Computer Engineering
ISBN:
9780133594140
Author:
James Kurose, Keith Ross
Publisher:
PEARSON
Computer Organization and Design MIPS Edition, Fi…
Computer Organization and Design MIPS Edition, Fi…
Computer Engineering
ISBN:
9780124077263
Author:
David A. Patterson, John L. Hennessy
Publisher:
Elsevier Science
Network+ Guide to Networks (MindTap Course List)
Network+ Guide to Networks (MindTap Course List)
Computer Engineering
ISBN:
9781337569330
Author:
Jill West, Tamara Dean, Jean Andrews
Publisher:
Cengage Learning
Concepts of Database Management
Concepts of Database Management
Computer Engineering
ISBN:
9781337093422
Author:
Joy L. Starks, Philip J. Pratt, Mary Z. Last
Publisher:
Cengage Learning
Prelude to Programming
Prelude to Programming
Computer Engineering
ISBN:
9780133750423
Author:
VENIT, Stewart
Publisher:
Pearson Education
Sc Business Data Communications and Networking, T…
Sc Business Data Communications and Networking, T…
Computer Engineering
ISBN:
9781119368830
Author:
FITZGERALD
Publisher:
WILEY