联系方式

您当前位置:首页 >> Python编程Python编程

日期:2024-09-24 11:45

Assignment Part B

Assignment Part B

Assignment Overview:

Assignments task you with applying the skills and knowledge you have learnt through the Ed

Lessons. They are no more difficult than the exercises in your Ed Lessons. You must meet all

competency requirements for each task to be marked as competent overall on the

assignment.

In Assignment Part B, we're going to continue to use our programming skills to customize and display

data for a user. These are basic examples of how many of the apps and websites you use every day

work. We've continued to look at some features of a fictional USyd Music app, an app like Spotify or

Apple Music that allows users to stream their favourite music.

Assignment Part B requires you to complete 5 tasks here in Ed Lessons;

Music Wrapped (Part 1)

Song Information

Music Wrapped (Part 2)

Song queues (Part 1)

Song queues (Part 2)

It should take you between 4 and 10 hours to complete, but do not leave it until the last minute to

attempt.

General instructions:

Please avoid changing function signatures

Assume that cases not mentioned in the specification will not be tested

Hard coding to pass test cases rather than constructing meaningful programs will result in a NSI

result return.

Missing code comments will result in a NI result return

Please avoid writing programs that are overly complex for the sake of it to "aim for a C*". C* is

designed to award work that is well structured, nuanced, and shows good/deep thinking about

code structure. It is inherent traits of your programming skills, as opposed to a list of things we

are looking for.

MAKE SURE YOU READ THE COMPETENCY REQUIREMENTS CAREFULLY!You must complete your code review in your schedule lab during week 9.

Competency requirements:

The competency requirements are summarized below (but are also listed on the page for each task).

You must meet all requirements to be awarded a Competent (C) for a question.

You must receive a minimum of Competent (C) for all questions to receive a Competent (C)

grade overall and move onto Assignment Part C.

To receive an Above Competent (C*) overall, you must receive an Above Competent (C*) in 3/5 tasks.

Full competency requirements outlined -

https://canvas.sydney.edu.au/courses/59287/pages/assignment-part-b-overview?

module_item_id=2431178 Testing vs Submitting Your Assignment

We have changed the interface to make it easier for us to determine when late submissions are

submitted. What this means for you is that you can use the 'test' button as many times as you would

like before officially submitting the assignment (bottom right hand side of the workspace). To

officially lodge your submission you will need to use the 'submit' button (top right hand side of the

workspace).

Any press of the submit button after 11:59pm on 22nd September will be counted as a late

submission. Late penalties will apply if you do not have special considerations or an academic

accommodations plan. Understanding Test Case Output

There will be 3 main types of test cases:

(UNIT) - Tests individual functions to check actions such as return values or modification of

attributes of an instance

(IO) - Tests a function to check if the values printed to stdout (terminal) is what was expected

(IO-UNIT) - Mix of Unit and IO where both return values, modification of attributes and stdout

will be tested altogether

Have a look at the examples below for a better understanding!

Example 1 [UNIT]

On the header you can find the information on what is being tested:

[Song] : Class/function being tested.

Constructor : Brief description of the test case.You will find the relevant output under Test Case Output where:

A brief description will tell you how your function/method was called. e.g with what

arguments.

Expected is what the the test case was expecting your function to do.

Got is what your function did/returned.

############## <END> ############# is a marker showing the end of the

expected/actual block (not to be printed or returned by your function).

Additional comments will give you additional information on the error. In this case, the

duration attribute is not correctly set

Example 2 [IO]

The header is similar to the previous exampleHighlighted in Green (+): Your program did not produce/output that line

Highlighted in Red (-): Your program produced an incorrect output and should be removed.

Example 3 [IO-UNIT]

The header is similar to the previous example

(stdout)->: This shows what your program should produce after each test case action.

If the IO-testing part of this test case fails, then you will see an additional output similar to [IO]

test cases shown in Example 2.If the unit-testing part of this test case fails, then you will see an additional output similar to

[UNIT] test cases shown in Example 1.Tips:

Sometimes the output of the cases in the diff view will not be helpful e.gThis will usually happen for IO-UNIT test cases. Switching to Your output view will be more helpful

in such cases.Music Wrapped (Part 1)

Write a program that verifies a user's username and password and displays the most

streamed song, artist, genre and total streaming hours for a specified month of a year. The

music wrapped will be displayed in a format specified in part 2.

This question involves knowledge from the following Ed Lessons (but not limited to):

IF statement

FOR loops

Break and continue

WHILE loops

Handling errors

Functions

Input/Output

In this part, we will ONLY focus on verifying user authentication.

Format of <username>.txt

The first line will always contain the password of the <username> . The rest of the lines contain the

details of the songs the user listens to each time. Each line will represent a single listening entry and

will be shown in the following format:

<password>

<song_name>,<artist>,<genre>,<song_duration>,<date>

<password> : The <username> 's password

<song_name> : The name of the song.

<artist> : The artist of the song

<genre> : The genre of the song

<song_duration> : The duration of the song, in the format mm:ss

<date> : The date the song was listened to, in the format DD-MM-YYYY

In this exercise, Music Wrapped you can assume that the format of the file <username>.txt is always

correct. All lines in the file will be case-sensitive.

Example of akali.txt

dowhat12kjk

Espresso,Sabrina Carpenter,Pop,04:22,23-02-2024

Ephemeral Dreamscape,Celestial Echoes,Rock,03:54,24-03-2024where the first line contains the password of the username akali and each of other lines contains

the single listening entry of username akali.

This example has also been given to you as part of the scaffold.

Part 1 - Username and Password

The program will begin by displaying the welcome message Welcome to USYD MUSIC! . It will then

continuously prompt the user for their username and password until a matching pair is found or 3

unsuccessful attempts have been made. The program will prompt for user's username and password

in the exact following format:

Welcome to USYD MUSIC!

Enter your username: <username>

Enter your password: <password>

where <username> and <password> are placeholder for user's input for username and password.

The function check_password(username, password) is implemented to check whether the input

<username> and <password> match those in the system. This function will first check whether

<username> exists in the USYD MUSIC system by checking the existence of <username>.txt in the

user_info directory (i.e folder).

If <username>.txt does not exist, the program will print No <username> found :(( , where

<username> is the user input, and returns False .

Otherwise, if <username>.txt exists, the program will check if the entered <password>

matches the password stored on the first line of the file.

If the password matches, print Login successful :)) and returns True .

Otherwise, print Username and password do not match :(( and return False .

If the function check_password returns True , exit the program. Otherwise, the program will go back

to prompt for the user's username and password. If the maximum number of 3 attempts has been

reached, the program will stop prompting for input and exit the program with the following message

Maximum of 3 attempts has been reached. You will be temporarily disabled from logginng

in :((

Example 1 - Matching Username and Password

$ python3 wrapped.py

Welcome to USYD MUSIC!

Enter your username: akali

Enter your password: dowhat12kjk

Login successful :))

Example 2 - Reaching 3 attempts$ python3 wrapped.py

Welcome to USYD MUSIC!

Enter your username: akali

Enter your password: dowhat12

Username and password do not match :((

Enter your username: aka

Enter your password: dowhat12kjk

No aka found :((

Enter your username: akali

Enter your password: idontknow

Username and password do not match :((

Maximum of 3 attempts has been reached. You will be temporarily disabled from logging in :((

Note: You can assume that all standard input are always valid. Lines that start with a $ indicates a

terminal command, which is an instruction you type into the terminal to run your program. Standard

inputs, which the user types into the terminal, are shown in bold.

Competency Requirements:

The test cases do not test that you meet all competency requirements. Please review the requirements

yourself even if you get a green tick. The green tick "mark" just checks if your code runs.

You can test your code as many times as you like before the submission deadline.Song Information

Write a Song class containing all song information and functionality relevant to the song.

This question involves knowledge from the following Ed Lessons (but not limited to):

Variables and data types

IF statements

CLASSES

The Song class will be used in all future exercises in Assignment Part B.

The program requires you to implement the Song class (including its attributes and methods) to store

all information on the songs and functionalities (i.e. methods) that are relevant to the Song objects.

Here are the instance attributes of a Song object.

Here are the instance methods of Song object.Competency Requirements:

The test cases do not test that you meet all competency requirements. Please review the requirements

yourself even if you get a green tick. The green tick "mark" just checks if your code runs.

You can test your code as many times as you like before the submission deadline.Music Wrapped (Part 2)

This question involves knowledge from the following Ed Lessons (but not limited to):

String formatting

IF statements

input() function

Containers (lists, tuples, and dictionaries

Mutable and Immutable data

WHILE and FOR loops

Handling errors

Functions

CLASSES

In this exercise, Music Wrapped, you can assume that the format of the file <username>.txt is always

correct. All lines in the file will be case-sensitive.

Write a program that verifies a user's username and password and displays the most

streamed song, artist, and genre within a specified month in a year. The music wrapped will

be displayed at the end of this part.

In this part, we will focus on creating the Music Wrapped Wall.

You will need to use the Song class in this exercise. You can just copy over the song.py file from the previous

exercise.

Part 2 - Wrapped Wall

The initial login part is the same as what you implemented in Part 1 and can be copied

over.

After a successful login, the program will ask for the specific with message Specify the month that

you want to display: . The input will be validated in the following order:

If the input is not an integer, print Month must be an integer :((

If the input is not within the range of , print Month must be between 1 and 12,

inclusively :((

[1, 12]

If the input is valid, the program will ask for the specific year with a message Specify the year

that you want to display: . The input will be validated in the following order:If the input is not an integer, print Year must be an integer :((

If the input is less than 2000, print Year must be larger than 2000 :((

You can assume that the user will not input a year larger than 2024.

Here we list the functions that you will implement and call within the main() function. Later we

provide details for each function.

You should be extracting the songs using the extract_song_details() function using the

username and the month and year provided by the user.

You should then use count_streams() with the extracted songs to find the number of times

each song, artist and genre has been listened to. Think about how the date_type parameters is

going to help you with that.

Once you have separate dictionaries for songs, artists and genres, you need to use the

find_most_frequent() function to find the most streamed song, artist and genre as tuples.

As you are also required to print the total streaming time, you need to use the

calculate_streaming_second() on the songs list to find the total streaming time in seconds.

Finally, you will pass the tuples and total streaming time to the print_rewind_wall() function

to print the final output.

extract_song_details()

Parameters:

filename: str : user file to extract songs from

month: int : month for which the songs need to be extracted from

year: int : year for which the songs need to be extracted from

Returns:

list[Song] : list of song objects extracted, each as a Song object

The first line will always contain the password of the <username> . The rest of the lines contain the

details of the songs the user listens to each time. Each line will represent a single listening entry and

will be shown in the following format:

<password>

<song_name>,<artist>,<genre>,<song_duration>,<date>

<password> : The <username> 's password

<song_name> : The name of the song.

<artist> : The artist of the song

<genre> : The genre of the song

<song_duration> : The duration of the song, in the format mm:ss

<date> : The date the song was listened to, in the format DD-MM-YYYYcount_streams()

Parameters:

songs: list[Song] : list of song objects

data_type: str : The song attribute for which we need the frequency. This will be either:

'song'

'artist'

'genre'

Returns:

dict[str: int] : A dictionary with the unique song, artist, or genre as keys and the

corresponding streaming counts as values. This should be in the format {song/genre/artist:

frequency, song/genre/artist: frequency,...} where

song/genre/artist is the name of a song, genre or artist depending on the data_type

parameter

frequency is how many times it appears in the songs list.

The count_streams() function will count the streaming frequency for each unique song, artist, or

genre (specified by the data_type parameter). The name of each unique song, artist, or genre will be

used as the key in the dictionary, while the number of streams will be stored as the value. During the

search, if the current song, artist, or genre is already in the dictionary, the streams count is

incremented by one.

You can assume that there will be at least one line for the specified month and year .

find_most_frequent()

Parameters:

streaming_data: dict[Song] : A dictionary containing the streaming data of a single

data_type

Returns:

tuple[str, int] : A tuple containing the key (song, artist, or genre) and its corresponding

number of streaming times.

The find_most_frequent() function will find the most frequently streamed song, artist, or genre.

This is done by iterating through a dictionary of song, artist, or genre data and identifying the keyvalue

pair with the largest streaming count. The function will return the key-value pair with the largest the streaming count as a tuple.

You can assume that there will be no ties.

calculate_streaming_seconds()

Parameters:

songs: list[Song] : list of song objects

Returns:

int : The total streaming seconds

The calculate_streaming_seconds() function will calculate the total streaming seconds from a list

of songs. This is done by iterating through all Song objects and adding their streaming time. This

function will return the total streaming seconds at the end.

print_wrapped_wall()

Parameters:

top_song: tuple(str, int) : the name of top song and its streaming frequency.

top_artist: tuple(str, int) : the name of top artist and its streaming frequency.

top_genre: tuple(str, int) : the name of top genre and its streaming frequency.

total_stream: int : the total streaming seconds

We will use the information about the total_streaming seconds and the most popular songs, artist

and genre within a specific time frame to display the Music Wrapped Wall. The function will first

display banner for the Wrapped Wall as follows:

****************************************************

MONTHLY MUSIC WRAPPED WALL

****************************************************

We then need to print the most streamed song, artist and genre in a specific format as follows:

Top Name Stream Times

Song <song_name> XXXX

Artist <artist_name> XXXX

Genre <genre_name> XXXX

Format specificationEach row will contain 3 columns: Top, Name, and Stream times.

Top : Left-padded with a column width of 8 characters.

Name : Left-padded with a column width of 32 characters.

Stream times : Displayed in a 4-digit format (XXXX) with leading zeros if necessary.

You can assume that all strings in the name column will be fewer than 31 characters long.

The function will then print the total listening hours as follows after converting it from seconds to

DD:HH:mm:ss .

****************************************************

Total streaming DD:HH:mm:ss

****************************************************

Remember to convert the seconds into days, hours, minutes and seconds in this function

Format Specifications:

Total streaming: Left-padded with a column width of 41 characters.

DD: Represents the number of whole streaming days with leading zeros.

HH: Represents the number of whole streaming hours with leading zeros.

mm: Represents the number of whole streaming minutes with leading zeros.

ss: Represents the number of streaming seconds with leading zeros.

You can assume that the stream times is a positive integer that less than 9999

Example of Monthly Wrapped

****************************************************

MONTHLY MUSIC WRAPPED WALL

****************************************************

Top Name Stream Times

Song Do you want to build a snowman 0020

Artist Elena Williams 0100

Genre Pop 0193

****************************************************

Total streaming DD:HH:mm:ss

End-to-end Examples

Sample 1 - akali$ python3 wrapped.py

Welcome to USYD MUSIC!

Enter your username: akali

Enter your password: dowhat12kjk

Login successful :))

Specify the month that you want to display: 2

Specify the year that you want to display: 2024

****************************************************

MONTHLY MUSIC WRAPPED WALL

****************************************************

Top Name Stream Times

Song Espresso 0002

Artist Sabrina Carpenter 0002

Genre Pop 0002

****************************************************

Total streaming 00:00:08:44

Sample 2 - karencat with invalid inputs

$ python3 wrapped.py

Welcome to USYD MUSIC!

Enter your username: karencat

Enter your password: password

Login successful :))

Specify the month that you want to display: ab

Month must be an integer :((

Specify the month that you want to display: 13

Month must be between 1 and 12, inclusively :((

Specify the month that you want to display: 6

Specify the year that you want to display: 6a

Year must be an integer :((

Specify the year that you want to display: 1999

Year must be larger than 2000 :((

Specify the year that you want to display: 2024

****************************************************

MONTHLY MUSIC WRAPPED WALL

****************************************************

Top Name Stream Times

Song Sunset Lover 0003

Artist The Weeknd 0004

Genre Pop 0004

****************************************************

Total streaming 00:00:32:59

These sample user files have been given to you as part of the scaffold.

Note: You can assume that all standard input are always valid. Lines that start with a $ indicates a

terminal command, which is an instruction you type into the terminal to run your program. Standard inputs, which the user types into the terminal, are shown in bold.

Competency Requirements:

The test cases do not test that you meet all competency requirements. Please review the requirements

yourself even if you get a green tick. The green tick "mark" just checks if your code runs.

You can test your code as many times as you like before the submission deadline.Song queues (Part 1)

Write a program that mimics the queue functionality of a music app. The program should

allow users to reset, append or modify existing queues and create a new queue. This task

will be divided into two parts.

The first part will focus on implementing a program that supports adding songs to the queue.

Just like the previous program, copy over your Song class to the song.py folder

This question involves knowledge from the following Ed Lessons (but not limited to):

String formatting

IF statements

input() function

Containers (lists, tuples, and dictionaries

Mutable and Immutable data

WHILE and FOR loops

Handling errors

Functions

CLASSES

You need to use add_song() and write_queue() functions that you will implement in the main()

function.

You need to first prompt the user for the queue mode. See Selecting the queue mode section

below

You then need to initialise an empty list as a queue.

You need to then get song inputs if a user is specified. See Getting song input section below

Here you will be checking whether the argument of <operation> is valid. If it is invalid,

print ***Invalid operation!*** and continue to prompt for next song input.

If a valid <operation> is provided, you should use load_song() function to help

initialise a Song object and add this to the queue using the add_song() function. The

songs will be added to the queue you initialised in point 2.

After the user enters END QUEUE , you will pass the final queue i.e the list of Song objects to

write_queue() function to write all songs in the queue into the <username>_queue.txt file in

the queue_info directory.

1. Selecting the queue mode

The program will receive the username of the users via command line arguments. If no command line argument are given, print No username found! and exit the programs. Otherwise, the program

will check for the existence of <username> 's queue by searching for <username>_queue.txt in the

queue_info directory.

If the <username>_queue.txt file does not exist:

The program will display No queue for <username> found! Creating a new queue...

and then prompt the user for song inputs. In this case, you will need to set the queue

mode to CREATE when calling the write_queue() function later (see below).

Otherwise, the program will ask the user to select between RESET or APPEND mode with the

message Do you want to reset or append to your queue?

If the user inputs RESET , the program will display Resetting your queue... and then

prompt the user for song inputs. You need to set the queue mode to RESET when calling

the write_queue() function to overwrite the file with the queue.

If the user inputs APPEND , the program will display Appending to your queue... . You

need to set the queue mode to APPEND when calling the write_queue() function to

write the queue below the existing queue in the file

If the user inputs neither of the above, the program will print Invalid mode! and return

to prompt for the queue mode.

The input for this prompt will be case-insensitive but space-sensitive (i.e., no leading or trailing

whitespace before or after the input).

Have a look at END-TO-END Examples at the bottom for examples.

2. Getting song input

The program will display a message Update songs in the queue: and ask the user to update the

queue via standard input. The user is expected to provide the details of the song exactly as specified

below:

<operation>,<song name>,<artist>,<genre>,<duration>

<operation> : specify whether the user wants to add ( A ) or not. operations are case sensitive,

meaning 'a' would be an invalid operation.

A : The program calls add_song() function to add song into the playlist.

Otherwise, prints ***Invalid operation!***

<song name> : The name of the song, with words.

<artist> : The name of the artist who sings the song.

<genre> : The genre of the song.

<duration> : The song duration in the format mm:ss .

Each argument will be separated by a comma , .

If the user inputs END QUEUE (case sensitive) , stop prompting the user and write the songs in the queue to the file.

You can assume that all song inputs are always in a correct format.

Have a look at END-TO-END Examples at the bottom for examples.

load_song_from_input()

Parameters:

input_song: str : The string that contains the song information in a correct format. This will

be the input given by the user in the form <operation>,<song name>,<artist>,<genre>,

<duration>

Returns:

Song : The Song object created using the information provided in the parameter.

The load_song_from_input() function parses the input song and extract all song's information. This

information is used to initialise a Song object.

add_song()

Parameters:

queue: list[Song] : list of Song objects

song: Song : The Song object to be added to the queue.

The add_song() function adds a song to the queue (called when the user input has value A in the

<operation> field). If a Song object with the same name and artist already exists in the queue, the

program will print ***'<song name>' by <artist> is already in the queue*** . You only need

to check this against the songs that are being input by the user NOT what exists in the file.

You can assume a user would not add a song to the queue that exists in the file.

Otherwise, the program will print ***'<song_name>' by <artist> is added to the queue*** and

add this Song object to the queue variable.

Think about why we do not need to return the queue to update the queue variable in the main function   write_queue()

Parameters:

filename: str : file to wrote the queue into.

queue: list[Song] : list of Song objects in the queue

queue_mode: str : The queue mode selected in "Selecting the queue mode" section. The queue

mode is either RESET, APPEND or CREATE

The write_queue() function writes all Song objects stored in the queue variable to the

<username>_queue.txt file in the queue_info directory. The file-open mode depends on the

selected queue mode:

CREATE: Create a new file to store the queue information and write the queue to it.

RESET: Overwrite the contents of the <username>_queue.txt file with the new queue.

APPEND: Write the new queue below the old queue in the <username>_queue.txt file.

Each song in the queue is written as a single line in the output file. The format of each line is as

follows:

<song name>,<artist>,<genre>,<song duration>

<song name> : The name of the song.

<artist> : The artist of the song.

<genre> : The genre of the song.

<song duration> : The duration of the song in the format mm:ss

Example of the output file karencat_queue.txt

Espresso,Sabrina Carpenter,Pop,04:22

Ephemeral Dreamscape,Celestial Echoes,Rock,03:54

END-TO-END Examples

Example 1 - No command line argument given

Terminal output

$python3 queue.py

No <username> found!

Example 2 - Queue does not exist: Createkarencat_queue.txt does not exist before the program is run

Terminal output

$python3 queue.py karencat

No queue for karencat found! Creating a new queue...

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is added to the queue***

Update songs in the queue: A,Twinkle star,Layla Smiths,Kids,02:22

***'Twinkle star' by Layla Smiths is added to the queue***

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is already in the queue***

Update songs in the queue: X,Magnificient,Sasha Scarlet,Pop,04:23

***Invalid operation!***

Update songs in the queue: END QUEUE

karencat_queue.txt will be created after the program is run

Magnificient,Sasha Scarlet,Pop,04:23

Twinkle star,Layla Smiths,Kids,02:22

Example 3 - Queue already exists: Append

karencat_queue.txt before the program is run

Espresso,Sabrina Carpenter,Pop,04:22

Ephemeral Dreamscape,Celestial Echoes,Rock,03:54

Terminal output

$python3 queue.py karencat

Do you want to reset or append to your queue? ApPEnD

Invalid mode!

Do you want to reset or append to your queue? APPED

Invalid mode!

Do you want to reset or append to your queue? aPPeND

Appending to your queue...

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is added to the queue***

Update songs in the queue: A,Twinkle star,Layla Smiths,Kids,02:22

***'Twinkle star' by Layla Smiths is added to the queue***Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is already in the queue***

Update songs in the queue: X,Magnificient,Sasha Scarlet,Pop,04:23

***Invalid operation!***

Update songs in the queue: END QUEUE

karencat_queue.txt after the program is run

Espresso,Sabrina Carpenter,Pop,04:22

Ephemeral Dreamscape,Celestial Echoes,Rock,03:54

Magnificient,Sasha Scarlet,Pop,04:23

Twinkle star,Layla Smiths,Kids,02:22

Example 4 - Queue already exists: Reset

karencat_queue.txt before the program is run

Espresso,Sabrina Carpenter,Pop,04:22

Ephemeral Dreamscape,Celestial Echoes,Rock,03:54

Terminal output

$python3 queue.py karencat

Do you want to reset or append to your queue? RESET

Resetting your queue...

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is added to the queue***

Update songs in the queue: A,Twinkle star,Layla Smiths,Kids,02:22

***'Twinkle star' by Layla Smiths is added to the queue***

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is already in the queue***

Update songs in the queue: X,Magnificient,Sasha Scarlet,Pop,04:23

***Invalid operation!***

Update songs in the queue: END QUEUE

karencat_queue.txt after the program is run

Magnificient,Sasha Scarlet,Pop,04:23

Twinkle star,Layla Smiths,Kids,02:22

Note: You can assume that all standard input are always valid. Lines that start with a $ indicates a terminal command, which is an instruction you type into the terminal to run your program. Standard

inputs, which the user types into the terminal, are shown in bold.

This means you can assume the user will:

Always provide correct number of arguments when adding the song to the queue

Will provide the correct arguments for the song

Competency Requirements:

The test cases do not test that you meet all competency requirements. Please review the requirements

yourself even if you get a green tick. The green tick "mark" just checks if your code runs.

You can test your code as many times as you like before the submission deadline.Song queues (Part 2)

Write a program that mimics the queue functionality of a music app. The program should

allow users to reset, append or modify existing queues and create a new queue.

This is the second part of song queues where you will focus on implementing features that allow users

to remove songs and replace songs in a specific position in the queue.

You can copy over functions that you have already implemented from the previous parts

This question involves knowledge from the following Ed Lessons (but not limited to):

String formatting

IF statements

input() function

Containers (lists, tuples, and dictionaries)

Mutable and Immutable data

WHILE and FOR loops

Handling errors

Functions

CLASSES

You need to use all functions in part 1 and additional replace_song() and remove_song()

functions in this task in the main() function. Here we list high-level functionality, and later we

provide detailed specifications for each function.

As carries on from part 1, your program will still receive the username of the users via

command line arguments. If no command line arguments are given, print No username

found! and exit the programs.

After that, your program should prompt user to select the queue mode until receive a valid

input as stated in the first part.

You then need to initialise an empty list as a queue (Similar to part 1).

After successfully selecting the queue mode, your program should prompt for song input until

the user enter END QUEUE . The format input of song is exactly the same as stated in part 1,

except your program should also handle ( R ) remove and ( S ) replace as other argument options

for <operation> .

If the <operation> is R , you should be removing a song from the queue using the

remove_song() function.

If the <operation> is S , you should ask for the position of the song they want to replace with the message: Which position do you want to replace this song with? . You

should then be replacing a target song in the queue with the replacement song specified

via input using the replace_song() function.

Your program continue prompt, and then add/remove/replace until the user enters END QUEUE .

You then pass the list of Song objects to write_queue() function to write all songs in the

queue into the <username>_queue.txt file.

remove_song()

Parameters:

queue: list[Song] : list of Song objects

song: Song : The Song object to be removed from the queue.

The remove_song() function removes a specified song from the queue if the user inputs R for

<operation> .This function iterates through a list of Song objects to find the Song object that

matches the name and artist of the input. If no Song objects in the queue match these, prints ***No

'<song_name>' by <artist> found, cannot remove it*** . Otherwise, prints ***Successfully

removed '<song_name>' by <artist>*** .

If the queue mode is APPEND , you cannot remove song details that have already been written to the output

file. You can only remove songs that the user inputs in.

replace_song()

Parameters:

queue: list[Song] : list of Song objects

song: Song : The Song object to be moved into the queue.

position: str : The position of the song to be replaced in zero base-indexing given by the

user.

The replace_song() function replaces a specified song with another at a specified position. This

function will check if the input position is valid. If the specified position is valid, prints

***Successfully replaced '<song_name1>' by <artist1> to '<song_name2>' by <artist2>*** ,

where <song_name1> and <artist1> are the name and artist of the input song and <song_name2>

and <artist2> are the name and artist of the song that got replaced. The song that gets replaced will

be removed from the queue.

Otherwise, the replace operation will not occur, and a corresponding error message will be printed.

The order of error checking is as follows:

Not an integer: Prints ***Position must be an integer***

Negative integer: Prints ***Position must be at least 0***

Out of range of the queue: Prints ***The specified position is out of range of the queue***

If the queue mode is APPEND , you cannot replace song details that have already been written to the output

file. You can only replace with the songs that the user inputs in.

END-TO-END Examples

Example 1 - Create mode with Remove and Add operations

karencat_queue.txt does not exist before the program is run

Terminal output

$python3 queue.py karencat

No queue for karencat found! Creating a new queue...

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is added to the queue***

Update songs in the queue: A,Twinkle star,Layla Smiths,Kids,02:22

***'Twinkle star' by Layla Smiths is added to the queue***

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is already in the queue***

Update songs in the queue: X,Magnificient,Sasha Scarlet,Pop,04:23

***Invalid operation!***

Update songs in the queue: R,Magnificient,Sasha Scarlet,Pop,04:23

***Successfully removed 'Magnificient' by Sasha Scarlet***

Update songs in the queue: R,Magnetic,Hyper,KPop,04:23

***No 'Magnetic' by Hyper found, cannot remove it***

Update songs in the queue: R,Magnificient,Sasha Scarlet,Pop,04:23

***No 'Magnificient' by Sasha Scarlet found, cannot remove it***

Update songs in the queue: END QUEUE

karencat_queue.txt will be created after the program is run

Twinkle star,Layla Smiths,Kids,02:22

Example 2 - Append mode with Remove and Add operations

karencat_queue.txt before the program is runEspresso,Sabrina Carpenter,Pop,04:22

Ephemeral Dreamscape,Celestial Echoes,Rock,03:54

Terminal output

$python3 queue.py karencat

Do you want to reset or append to your queue? ApPEnD

Invalid mode!

Do you want to reset or append to your queue? APPED

Invalid mode!

Do you want to reset or append to your queue? aPPeND

Appending to your queue...

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is added to the queue***

Update songs in the queue: A,Twinkle star,Layla Smiths,Kids,02:22

***'Twinkle star' by Layla Smiths is added to the queue***

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is already in the queue***

Update songs in the queue: A,Beauty and the beast,Alena,Ballad,06:17

***'Beauty and the beast' by Alena is added to the queue***

Update songs in the queue: R,Do you want to build a snowman?,Elsa,Kids,03:14

***No 'Do you want to build a snowman?' by Elsa found, cannot remove it***

Update songs in the queue: R,Magnificient,Sasha Scarlet,Pop,04:23

***Successfully removed 'Magnificient' by Sasha Scarlet***

Update songs in the queue: END QUEUE

karencat_queue.txt after the program is run

Espresso,Sabrina Carpenter,Pop,04:22

Ephemeral Dreamscape,Celestial Echoes,Rock,03:54

Twinkle star,Layla Smiths,Kids,02:22

Beauty and the beast,Alena,Ballad,06:17

Example 3 - Create mode with Add and replace operations

karencat_queue.txt does not exist before the program is run

Terminal output

$python3 queue.py karencat

No queue for karencat found! Creating a new queue...Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is added to the queue***

Update songs in the queue: A,Twinkle star,Layla Smiths,Kids,02:22

***'Twinkle star' by Layla Smiths is added to the queue***

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is already in the queue***

Update songs in the queue: X,Magnificient,Sasha Scarlet,Pop,04:23

***Invalid operation!***

Update songs in the queue: A,Beauty and the beast,Alena,Ballad,06:17

***'Beauty and the beast' by Alena is added to the queue***

Update songs in the queue: S,Magnetic,Hyper,KPop,04:23

Which position do you want to replace this song with? 1

***Successfully replaced 'Twinkle star' by Layla Smiths to 'Magnetic' by Hyper***

Update songs in the queue: S,All by me,Jasper,KPop,05:34

Which position do you want to replace this song with? 10

***The specified position is out of range of the queue***

Update songs in the queue: S,All by me,Jasper,KPop,02:34

Which position do you want to replace this song with? ten

***Position must be an integer***

Update songs in the queue: S,All by me,Jasper,KPop,05:22

Which position do you want to replace this song with? -10

***Position must be at least 0***

Update songs in the queue: END QUEUE

karencat_queue.txt will be created after the program is run

Magnificient,Sasha Scarlet,Pop,04:23

Magnetic,Hyper,KPop,04:23

Beauty and the beast,Alena,Ballad,06:17

Example 4 - Append mode with replace and Add operations

karencat_queue.txt before the program is run

Espresso,Sabrina Carpenter,Pop,04:22

Ephemeral Dreamscape,Celestial Echoes,Rock,03:54

Terminal output

$python3 queue.py karencat

Do you want to reset or append to your queue? AppendAppending to your queue...

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is added to the queue***

Update songs in the queue: A,Twinkle star,Layla Smiths,Kids,02:22

***'Twinkle star' by Layla Smiths is added to the queue***

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is already in the queue***

Update songs in the queue: X,Magnificient,Sasha Scarlet,Pop,04:23

***Invalid operation!***

Update songs in the queue: A,Beauty and the beast,Alena,Ballad,06:17

***'Beauty and the beast' by Alena is added to the queue***

Update songs in the queue: S,Magnetic,Hyper,KPop,04:23

Which position do you want to replace this song with? 1

***Successfully replaced 'Twinkle star' by Layla Smiths to 'Magnetic' by Hyper***

Update songs in the queue: S,All by me,Jasper,KPop,05:34

Which position do you want to replace this song with? 10

***The specified position is out of range of the queue***

Update songs in the queue: S,All by me,Jasper,KPop,02:34

Which position do you want to replace this song with? ten

***Position must be an integer***

Update songs in the queue: S,All by me,Jasper,KPop,05:22

Which position do you want to replace this song with? -10

***Position must be at least 0***

Update songs in the queue: END QUEUE

karencat_queue.txt after the program is run

Espresso,Sabrina Carpenter,Pop,04:22

Ephemeral Dreamscape,Celestial Echoes,Rock,03:54

Magnificient,Sasha Scarlet,Pop,04:23

Magnetic,Hyper,KPop,04:23

Beauty and the beast,Alena,Ballad,06:17

Example 5 - Reset with all operations

karencat_queue.txt before the program is run

Espresso,Sabrina Carpenter,Pop,04:22

Ephemeral Dreamscape,Celestial Echoes,Rock,03:54Terminal output

$python3 queue.py karencat

Do you want to reset or append to your queue? reset

Resetting your queue...

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is added to the queue***

Update songs in the queue: A,Twinkle star,Layla Smiths,Kids,02:22

***'Twinkle star' by Layla Smiths is added to the queue***

Update songs in the queue: A,Magnificient,Sasha Scarlet,Pop,04:23

***'Magnificient' by Sasha Scarlet is already in the queue***

Update songs in the queue: A,Beauty and the beast,Alena,Ballad,06:17

***'Beauty and the beast' by Alena is added to the queue***

Update songs in the queue: R,Do you want to build a snowman?,Elsa,Kids,03:14

***No 'Do you want to build a snowman?' by Elsa found, cannot remove it***

Update songs in the queue: R,Magnificient,Sasha Scarlet,Pop,04:23

***Successfully removed 'Magnificient' by Sasha Scarlet***

Update songs in the queue: S,Starlight,Bobby,Pop,05:12

Which position do you want to replace this song with? 0

***Successfully replaced 'Twinkle star' by Layla Smiths to 'Starlight' by Bobby***

Update songs in the queue: END QUEUE

Output file karencat_queue.txt

Starlight,Bobby,Pop,05:12

Beauty and the beast,Alena,Ballad,06:17

Note: You can assume that all standard input are always valid. Lines that start with a $ indicates a

terminal command, which is an instruction you type into the terminal to run your program. Standard

inputs, which the user types into the terminal, are shown in bold.

Competency Requirements:

The test cases do not test that you meet all competency requirements. Please review the requirements

yourself even if you get a green tick. The green tick "mark" just checks if your code runs.

You can test your code as many times as you like before the submission deadline.Log of Changes

The changes will only contain reclarifications of description and inconsistencies in the docstring / type-hints.

We aim to have no changes to the actual code implementation.

The changes as of now is simply miscellaneous and very small. It would be faster to just copy and paste it over.

However, you may also click the ... and click Reset to Scaffold which will give you an up to date scaffold.

Ensure you first submit your code before resetting to scaffold with this so you can copy all your

implementation back over.

  Extra Pinned Changes

 Pinned Changes

20/09

3:20pm:

Changed the name of testcase "[Song] is_identical True and False (UNIT)" to "[Song] is_same True and

False (UNIT)" and fixed its bugs.

2:00pm:

Fixed the docstring for the parameter song of the function replace_song() , from "removed from"

to "moved into".

16/09

10:20am

Fixed the scaffold for song.py to fix misspelled method names and missing methods for exercises

after Song Informatiion. Please copy over your solution from Song Information to the song.py

files in the rest of the exercises.

10/09

6:00pm

The format specification of Top for print_wrapped_wall() in Music Wrapped (Part 2) was changed

from 6 characters to 8 characters to match the expected output for the test cases.3:00pm

The scaffold for Song.py was updated for all Song Queues to fix the constructor. Please copy over

your song.py file from previous exercises or just reset to scaffold to pull latest changes.

The condition in Song Queues (Part 1) if __name__ == '__main__' was fixed to include == instead

of = . You can fix this or just reset to scaffold to pull latest changes.

12:15pm

The scaffold for queue.py was updated for Song Queues (Part 2) to change the swap_song()

method to replace_song() as specified in the question description. Please rename the method to

pass test cases or just reset to scaffold to pull latest changes.

10:30am

The example and test cases were fixed to correct the spelling of logging .

$ python3 wrapped.py

Welcome to USYD MUSIC!

Enter your username: akali

Enter your password: dowhat12

Username and password do not match :((

Enter your username: aka

Enter your password: dowhat12kjk

No aka found :((

Enter your username: akali

Enter your password: idontknow

Username and password do not match :((

Maximum of 3 attempts has been reached. You will be temporarily disabled from logging in :((

09/09

10:30pm

The example snippets for print_wrapped_wall() had extra whitespaces after Stream Times for first

song and the test case was expecting 'MONTHLY MUSIC REWIND WALL' instead of 'MONTHLY MUSIC

WRAPPED WALL'. The examples and the test cases have now been fixed, please refresh the page to

remark and resubmit.

****************************************************

MONTHLY MUSIC WRAPPED WALL

****************************************************

Top Name Stream Times

Song Do you want to build a snowman 0020

Artist Elena Williams 0100Genre Pop 0193

****************************************************

Total streaming DD:HH:mm:ss

3:30pm

The scaffold for Song.py was updated for all exercises to change the has_same_duration() method

to get_longest() as specified in the question description. Please rename the method to pass test

cases or just reset to scaffold to pull latest changes.Code Review - In Week 9 Lab

Do not forget to turn up for your code review in the Week 9 Lab.

If you are unable to attend, you will need to apply for special consideration. For more details on the

special consideration process and instructions on how to apply -

https://canvas.sydney.edu.au/courses/59287/pages/special-consideration?module_item_id=2468718


版权所有:留学生编程辅导网 2020 All Rights Reserved 联系方式:QQ:821613408 微信:horysk8 电子信箱:[email protected]
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:horysk8