python list函数替换逗号为竖杠_python 3实现从txt文件读取,把列表(List)中字符串转整数,并用逗号分开...

最近科研遇到这样一个需求:把list里的字符串转化为整数:

例如:

list=['1','2','3','4','5']

转化为:

list=[1,2,3,4,5]

在产生200位bit的随机二进制秘钥,这些秘钥都是保存在txt格式的文本中的,文本中的数据格式如下所示:

8105d30eb2cc82220d4cd86ce73d1493.png

我现在需要把这些秘钥都读取出来,并且每个秘钥的后面要用逗号隔开,

bits=[1,1,0,1,0,0,1,1,0,1,1,1,1,1,1,1,0,1,0,1,1,1,1,0,1,1,0,1,0,1,0,1,1,0,1,

1,1,0,1,0,0,0,0,1,0,1,1,1,1,0,0,0,0,1,0,1,0,1,1,0,1,1,1,0,0,0,0,1,0,1,0,1,1,

1,0,0,1,1,1,1,1,1,0,1,1,1,1,0,1,1,0,0,0,0,0,0,1,1,1,1,1,1,0,1,1,1,1,1,0,0,1,

1,1,1,1,1,1,1,1,1,0,0,0,1,0,0,0,0,0,1,1,1,0,1,0,0,1,0,0,0,0,1,1,1,1,0,0,1,1,

1,0,0,0,1,0,1,1,0,0,0,0,0,1,0,0,0,1,1,1,1,0,1,0,1,1,0,0,0,1,0,0,1,1,1,0,0,1,

1,1,0,0,1,0,1,1,1,1,0,1,1,1,0,0,0,1,1,0,1,1,1,0,1,1,0,1,0,0,1,1,1,1,1,1,1,1,

1,1,0,0,1,0,0,0,1,1,1,1,0,1,1,0,0,1,0,0,1,1,1,1,0,1,1,1,0,0,1,0,1,0,1,1,1,0,

0,0,1,0,0,1,1,0,0,1,1,1,0,0,1,0,1,0,1,1,0,1,1,1,1,1,0,1,0,1,0,1,1,1,0,1,1,1,

1,0,0,0,0,0,1,1,1,1,1,1,1,0,0,1,0,1,1,0,0,0,1,1,1,1,0,1,0,1,1,0,0,1,1,1,1,1,

0,1,1,0,1,0,1,0,1,1,1,0,1,0,0,1,1,0,1,1,1,1,1,0,0,1,1,0,1,1,0,0,1,1,1,1,0,0,1,0]

然后用python来处理这些数据 ,所以现在问题就在于怎么把数据从txt文件中读取出来,然后保存成上面这个样子。

发现一个问题,就是直接使用file.readlines()这个方法读取出来的不是自己想要的结果:如下:

file = open('D:\\123.txt')

lines = file.readlines()

print(lines)

上面代码执行结果如下:显然不是我想要的

9cc63608c73be6d9fcdfe932227644fa.png

看上面的代码,我们发现有下面几个问题:

①包含字符串' '

②最后多了一个\n

那么就要解决掉这些问题: 代码如下

#读取文件

file = open('D:\\123.txt')

lines = file.readlines()

# print(lines)

strr=''.join(lines)

bits=[]

for line in strr:

for ind in line:

# ts=int(ind)

bits.append(ind)

bits.remove('\n')

for index,item in enumerate(bits):

bits[index]=eval(item)

print(bits)

执行结果如下:

d62f9cca17bd76cadce13d104fcc7b83.png

达到了自己想要的结果。

如果您不想使用pandas库,也可以使用Python将DeepFashion数据集list_attr_img.txt文件换为CSV文件。可以按照以下代码进行操作: ```python # 读取list_attr_img.txt文件 with open('list_attr_img.txt', 'r') as f: lines = f.readlines() # 处理每行数据 data = [] for line in lines[2:]: line = line.strip().split() img_path = line[0] attrs = line[1:] attrs = [int(x) for x in attrs] data.append([img_path] + attrs) # 将数据保存为CSV文件 with open('list_attr_img.csv', 'w') as f: # 写入列名 f.write('image_name,') f.write(','.join(lines[1].strip().split()[1:]) + '\n') # 写入数据 for line in data: line = [str(x) for x in line] f.write(','.join(line) + '\n') ``` 解释: 1. 首先使用open()函数读取list_attr_img.txt文件,将每行数据读取为一个字符串。 2. 对于每行数据,使用strip()函数去除空格和换行符,并使用split()函数将其拆分为图像路径和属性值。 3. 将属性值换为整数类型。 4. 将图像路径和属性值组成一个列表,并添加到data列表。 5. 使用open()函数创建CSV文件,并使用write()函数将data列表的数据写入CSV文件。在写入CSV文件时,首先使用join()函数将列名换为一个字符串,然后写入CSV文件;接着,使用join()函数将每行数据换为一个字符串,并使用逗号分隔每个数据项。 这样,就可以使用Python将DeepFashion数据集list_attr_img.txt文件换为CSV文件了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值