`
yy_gy
  • 浏览: 35454 次
  • 性别: Icon_minigender_2
社区版块
存档分类
最新评论

Google python babyname.py (python 2.7)

阅读更多
#!/usr/bin/python

import sys
import re

"""Baby Names exercise

Define the extract_names() function below and change main()
to call it.

For writing regex, it's nice to include a copy of the target
text for inspiration.

Here's what the html looks like in the baby.html files:
...
<h3 align="center">Popularity in 1990</h3>
....
<tr align="right"><td>1</td><td>Michael</td><td>Jessica</td>
<tr align="right"><td>2</td><td>Christopher</td><td>Ashley</td>
<tr align="right"><td>3</td><td>Matthew</td><td>Brittany</td>
...

Suggested milestones for incremental development:
-Extract the year and print it
-Extract the names and rank numbers and just print them
-Get the names data into a dict and print it
-Build the [year, 'name rank', ... ] list and print it
-Fix main() to use the extract_names list
"""

def extract_names(filename):
  """
  Given a file name for baby.html, returns a list starting with the year string
  followed by the name-rank strings in alphabetical order.
  ['2006', 'Aaliyah 91', Aaron 57', 'Abagail 895', ' ...]
  """
  if re.search(r'[0-9]{4}',filename):
    year=re.search(r'[0-9]{4}',filename).group()
  else:
    sys.exit(1)
  f=open(filename)
  cont=f.read()
  f.close()
  dic=[]
  male_dict=[]
  all_dict=re.findall('<tr align="right"><td>([0-9]+)</td><td>([A-Z][a-z]+)</td><td>([A-Z][a-z]+)',cont)
  for name in all_dict:
    male_dict.append(name[1]+'  '+name[0])
    dic.append(name[2]+'  '+name[0])
  dic.sort()
  male_dict.sort()
  male_dict.insert(0,'-'*30+'Male'+'-'*30)
  dic.insert(0,year)
  dic.insert(1,'-'*30+'Female'+'-'*30)
  dic.extend(male_dict)
  return dic



def main():
  # This command-line parsing code is provided.
  # Make a list of command line arguments, omitting the [0] element
  # which is the script itself.
  args = sys.argv[1:]

  if not args:
    print 'usage: [--summaryfile] file [file ...]'
    sys.exit(1)

  # Notice the summary flag and remove it from args if it is present.
  summary = False
  if args[0] == '--summaryfile':
    summary = True
    del args[0]

  for arg in args:
    names=extract_names(arg)
    print '\n'.join(names)
    if summary:
      sf=open(names[0]+'.txt','w')
      sf.write('\n'.join(names)+'\n')

 
if __name__ == '__main__':
  main()
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics