[英]How to append lines from text file to multiple lists in python 3x
我的问题是我有一个包含以下内容的文本文件:
♦J
♣J
♠J
♣8
♦A
♥9
♥J
♥J
♦A
♦K
♦7
♦J
♦7
♦A
♦K
♥7
♣10
♣J
♠A
♦A
♣J
♦7
♠10
♥K
♣9
♥10
♦A
♠8
♠J
♥9
♦8
♠A
我正在尝试将 append 按从下到下的顺序排列到 8 个不同的列表中。 我有 8 个不同的列表和一个列表,其中包含它们设置的所有不同列表,如下所示:
deckOne = []
deckTwo = []
DeckThree = []
DeckFour = []
deckFive = []
deckSix = []
deckSeven = []
deckEight = []
deckList = [deckOne, deckTwo, DeckThree, DeckFour, deckFive, deckSix, deckSeven, deckEight]
运行程序时我没有收到任何错误,但是我没有得到我期望的 output。 预期的 output 将如下所示:
[♦J, ♣J, ♠J, ♣8]
[♦A, ♥9, ♥J, ♥J]
[♦A, ♦K, ♦7, ♦J]
[♦7, ♦A, ♦K, ♥7]
[♣10, ♣J, ♠A, ♦A]
[♣J, ♦7, ♠10, ♥K]
[♣9, ♥10, ♦A, ♠8]
[♠J, ♥9, ♦8, ♠A]
但我目前得到的结果是这样的:
[['♦J', '♦A', '♣10', '♣9'], ['♣J', '♦K', '♣J', '♥10'], ['♠J', '♦7', '♠A', '♦A'], ['♣8', '♦J', '♦A', '♠8'], ['♦A', '♦7', '♣J', '♠J'], ['♥9', '♦A', '♦7', '♥9'], ['♥J', '♦K', '♠10', '♦8'], ['♥J', '♥7', '♥K', '♠A']]
这个 output 是错误的,因为它将文件中的每 4 行而不是 4 行附加到一个列表,然后将下 4 行附加到下一个列表,依此类推。 我试图用来执行此操作的代码是:
def hentLagretSpill():
import codecs
with codecs.open("game_save.txt", 'rb', encoding="utf-8") as gameGetter:
count = 0
for i, l in enumerate(gameGetter):
count += 1
deckList[i % 8].append(l.strip())
print(deckList)
但我也试过这个,它有效,但很长:
x = -1
for line in gameGetter:
x += 1
if x // 4 == 0:
deckOne.append(line.strip('\n'))
if x // 4 == 1:
deckTwo.append(line.strip('\n'))
if x // 4 == 2:
DeckThree.append(line.strip('\n'))
if x // 4 == 3:
DeckFour.append(line.strip('\n'))
if x // 4 == 4:
deckFive.append(line.strip('\n'))
if x // 4 == 5:
deckSix.append(line.strip('\n'))
if x // 4 == 6:
deckSeven.append(line.strip('\n'))
if x // 4 == 7:
deckEight.append(line.strip('\n'))
我将如何解决这个问题?
您看到的问题是%
(模)运算符返回余数,而不是第二个示例中的 integer 除法。 您可以通过返回 integer 分区并将其用作列表列表中的索引来修复它。
def hentLagretSpill():
with open("game_save.txt", 'r', encoding="utf-8") as gameGetter:
for i, l in enumerate(gameGetter):
ix = i // 4
deckList[ix].append(l.strip())
print(deckList)
# prints:
[['♦J', '♣J', '♠J', '♣8'],
['♦A', '♥9', '♥J', '♥J'],
['♦A', '♦K', '♦7', '♦J'],
['♦7', '♦A', '♦K', '♥7'],
['♣10', '♣J', '♠A', '♦A'],
['♣J', '♦7', '♠10', '♥K'],
['♣9', '♥10', '♦A', '♠8'],
['♠J', '♥9', '♦8', '♠A']]
另一种方式,使用itertools.islice
假设您在f
中有文件内容
from itertools import islice
to_split=iter(f.strip().splitlines())
split_list=[list(islice(to_split,4)) for _ in range(8)]
for i in split_list:
print(i)
再三考虑,您可以使用列表切片在没有islice
的情况下这样做
split_list=[to_split[split_idx:split_idx+4] for split_idx in range(0,len(to_split),4)]
这打印
['♦J', '♣J', '♠J', '♣8']
['♦A', '♥9', '♥J', '♥J']
['♦A', '♦K', '♦7', '♦J']
['♦7', '♦A', '♦K', '♥7']
['♣10', '♣J', '♠A', '♦A']
['♣J', '♦7', '♠10', '♥K']
['♣9', '♥10', '♦A', '♠8']
['♠J', '♥9', '♦8', '♠A']
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.