联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

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

日期:2018-04-21 09:09

Question 1 - Random Sentence Generator - 7 marks

Write a program that reads in files of words and produces random but structurally correct English

sentences, according to the syntax (rules of grammar) specified on the next page.

Here is the output of a demo program. These sentences are correctly structured English but (usually) make

absolutely no sense (but are often fun :-)

It is commonly believed that your ghastly Mortician deliberately befriends my annoying bulb.

Lo! our green lecturer often hibernates.

This foreign burglar usually cooks and ate the flesh of her inconceivable colour.

Indeed, the orbiting boy inexorably recognizes this half-hidden monstrosity.

My vaporized model knowingly reaches an understanding with his dainty terror.

Additional data files:

• RandomSentenceWordlists.zip on Stream has files for each class of word,

e.g. Nouns.txt, Adjectives.txt, …

• Important: put the files from Wordlists.zip into the same folder as your Python file.

Commands

Make the following commands available using a menu and prompt for a command. The commands can be

upper or lower case (e.g. e or E) or either. It'll be easier if you implement the commands in order (L first

…)

CMD Effect

L Load all the files of words from disk.

T Test – display the first word from each list to make sure they've been loaded.

E Easy sentence: display a two word sentence - a randomly selected noun followed

by a randomly selected intransitive verb and then a full stop.

S new Sentence - generate & display a sentence conforming to the grammar defined

in the 'Use this grammar to make your sentences' section on the next page.

If the wordlists haven't been loaded, display an error message.

Q Quit the program.

For full marks

• the sentences should be capitalised correctly and have a trailing full stop.

• the sentences generated by the “S” command should conform to the specified grammar

• meaningful variable names should be used & any complex parts should be commented

The explanation on the next page is a little wordy but the idea underlying is simple – you randomly select

words from appropriate word lists and combine them so they're correct English sentences.

159.171 – Assignment 3 1 © Giovanni Moretti 2017

Defining the Structure of Sentences

We all know what sounds right as a sentence, but to create correct sentences using a program, we have to

be more precise.

Below, I've defined a grammar that specifies the syntax (i.e. the structure) of valid tiny sentences.

What the symbols mean when defining a grammar:

 ::= is read as “is defined as”.

 Square brackets [ ] around an item mean that item is optional (it can be omitted).

 the vertical bar | means OR (choose the item to the left OR the item right)

 Angle brackets (e.g. < > ) around an item means it’s a placeholder that will be replaced later.

EXAMPLE: to illustrate how a grammar can be defined and used, say we have four named lists of

words, (e.g. <Noun> is the name of the first group)

<Noun-marker> our, my, the

<Adjective> red, huge, slimy

<Noun> cat, fire, sky

<Verb> eats, climbs, digs up

and the following rule defines valid Noun-Phrases:

<Noun-Phrase> ::= [ <Noun-marker> ] [ <Adjective> ] <Noun>

Square brackets around an item means it's optional, so both the Noun-marker and Adjective can be

omitted. Therefore the following five noun phrases all comply with the above Noun-Phrase definition:

1) cat 2) our fire 3) our slimy sky (4) huge fire (5) my red cat

Just for this example, let the definition for Sentence be:

Sentence ::= Noun-Phrase Verb Noun-phrase

the red cat eats our slimy sky

our sky climbs the huge fire

my cat digs up the red sky

Capitalise the first word & add a full stop, and each of these three lines is a silly but valid sentence.

Use this grammar to make your sentences

The following grammar defines the structure of a sentence for your answer to this assignment question.

<Sentence>::= [<Lead-in>] <Noun-Phrase> [<Adverb>] <Verb-Phrase> .

Read this as: “a sentence is defined as a Lead-in (which, because is surrounded by square brackets, is

optional) followed by a Noun-phrase, an optional Adverb, then a Verb-Phrase and a full stop”.

<Noun-Phrase> ::= <Noun-marker> [ <Adjective> ] <Noun>

<Verb-Phrase> ::= <Intransitive-verb> | <Transitive-verb> <Noun-phrase>

is read as: "A verb phrase can be an intransitive verb OR a transitive-verb1

followed by a noun phrase"

Where <Noun> means any line from the Nouns.txt file, and likewise for the others (e.g. <Adjectives> ...)

1

transitive-verbs take an object (there must be a noun after the verb) e.g. the cat bounced the ball

159.171 – Assignment 3 2 © Giovanni Moretti 2017

Suggestions

 Optional items are included 50% of the time. To control this, you can use

the random.random() function which returns a real number somewhere between 0 and 1, or

random.choice( ['heads', 'tails'] ) - try it and see what it does

Don't forget to import the random module

 There are many ways to build the sentence:

 you can print out each word as you go. This method is simple but has the limitation that

you never have the complete sentence as a string.

 you can build up the sentence by making a string that gets longer as you add the next part

of the sentence :

e.g. s = a random selection from Leadin

s = s + random selection from NounMarker # and keep adding

 you could add the pieces to a list and then join them together using '' '.join(your-list)

 Your program will have a cleaner structure and be easier to follow if you create functions for

<noun-phrase> and <verb-phrase>, and possibly <sentence> as well.

 You may find s.capitalize() useful.

Possible extensions

This is fun program and there are lots of way you could extend it. You could:

• remember a noun from one sentence and reusing it in the next sentences

• there's a conjunction wordlist (e.g. and) which isn't currently used. You could make your program

create paragraphs by creating multiple sentences joined with conjunctions, possibly repeating the

nouns to provide some continuity

• make it remember all the sentences created in a list.

• add a Favourites command which adds the most recently created sentence to a list of favourites.

159.171 – Assignment 3 3 © Giovanni Moretti 2017

Question 2 – An Addressbook – 7 marks

Using a dictionary indexed by nickname (a short favourite name), write a simple address book that

lets you save these contact details.

• nickname (can be anything you like)

• name

• address

• phone-no

Each dictionary entry contains a dictionary of the details of that person, so

names['Tom'] # will return the dictionary that contains all of Tom's details,

and

contacts = names['Tom"]

address = contacts['address']

or simply

address = contacts['Tom']['address']

will return Tom's address

The program first displays a menu (something like that shown below) and carries out the appropriate

action depending on which letter the user types, and then redisplays the menu:

*** My Contacts ***

f – find

a – add new entry

d – delete

l – list all

q – quit

command: ?

add prompt separately for each of name, address, phone-no and nickname. Then save all of these

fields into a data structure. A dictionary is recommended but a list will also work.

find prompt for a nickname, then search for the name, address and phone number of the person

with this nickname in your addressbook and display their details. Make the search is caseinsensitive

i.e. only the letters matter, not whether they're upper or lower case

delete prompt for a nickname, then find and display the related entry. Ask the user if this is the

correct one to be deleted. If they reply "yes" delete it.

list all As expected list all the entries, numbered sequentially. Display all the fields and format them

for easy reading. Some possibilities are shown below.

Across

Nick Name Address Phone No

1 sue Sue Williams 104 Broadway, Pnth 021-333-5555

2 bob Robert Levine 25 Fitzherbert Ave 06-355-6666

Down

1 sue

Sue Williams

25 Broadway, PNth

021-333-5555

2 bob

Robert Levine

104 Fitzherbert Ave

06-355-6666

159.171 – Assignment 3 4 © Giovanni Moretti 2017

Does the name exist?

When adding entries, as soon as the nickname is given, check to see if that nickname in the addressbook.

If so, ask if the new entry should replace the existing one for that nickname. If the answer is no, then

prompt again for a new nickname. To abort the add command (and find/delete), simply enter an empty

string for the nickname.

Be sure to an appropriate message if the user tries to find or delete an entry and the nickname isn't in use.

IMPORTANT: make sure that you use functions, usually one for each of the commands. You can of

course, create any additional functions that you think will help to simplify or clarify your code.

The Addressbook - Getting Started:

1. get the menu going and then create a function for each of list-all, add, … Initially, simply put a

print inside each function, e.g. for the addEntry function, put print("You called ADD"). You can

test each command – they'll simply print out a message.

2. using an assignment statement, manually create a tiny addressbook containing a two or three

entries

3. get the list-all command going. You can use this to view your manually created addressbook and

effects of the later commands

4. then work on add, find and delete

Optional (you can get full marks without doing this): you could try adding a s (search) command that

searches for and displays all entries that have the search string in any of the fields (not just the nickname).

What and how to submit

How: ALL submissions must be via Stream (not email) using the Assignment 3 submission link.

What: Submit your Python programs, each named with .py extensions. You should have three .py files to

submit, one for each question.

Do not submit Word documents (.doc or .docx) or .zip files.

Check that:

 all programs should display your name and ID number when starting.

 that your files have a .py extension

159.171 – Assignment 3 5 © Giovanni Moretti 2017


相关文章

【上一篇】:代写Python Golf Game
【下一篇】:代写Python Golf Game

版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp