我没有把这个问题弄好。函数read_words
将带有一堆新名称的文本文件转换为一个列表,然后就可以了。
def read_words(words_file):
""" (file open for reading) -> list of str
Return a list of all words (with newlines removed) from open file
words_file.
Precondition: Each line of the file contains a word in uppercase characters
from the standard English alphabet.
"""
words_list = []
words = words_file.readlines()
for i in range(len(words)):
new_word = words[i]
for char in '\n':
new_word = new_word.replace(char,'')
words_list.append(new_word)
return words_list
当我尝试获取列表列表时出现问题
def read_board(board_file):
""" (file open for reading) -> list of list of str
Return a board read from open file board_file. The board file will contain
one row of the board per line. Newlines are not included in the board.
"""
board_list = []
row_list = []
rows = read_words(board_file)
for i in range(len(rows)):
for char in rows[i]:
row_list.append(char)
board_list.append(row_list)
return board_list
目标是转换类型为
的文本文件ABCD
EFGH
进入[['A','B','C','D'],['E','F','G','H']]
我已经尝试过使用board_list.append(row_list)
电话的索引而没有运气。我怎样才能让它发挥作用?
答案 0 :(得分:3)
您可以使用list comprehension和.strip()
来执行此操作:
def read_board(board_file):
return [list(line.strip()) for line in read_words(board_file)]
def read_words(words_file):
""" (file open for reading) -> list of str
Return a list of all words (with newlines removed) from open file
words_file.
Precondition: Each line of the file contains a word in uppercase characters
from the standard English alphabet.
"""
return [word.strip() for word in words_file.readlines()]
def read_board(board_file):
""" (file open for reading) -> list of list of str
Return a board read from open file board_file. The board file will contain
one row of the board per line. Newlines are not included in the board.
"""
return [list(line) for line in read_words(board_file)]
with open('file1', 'rU') as f:
board = read_board(f)
print(board)
[['A', 'B', 'C', 'D'], ['E', 'F', 'G', 'H']]