繁体   English   中英

如何将 append 行从文本文件到 python 中的多个列表 3x

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM