用python如何实现自动编号? 100
如图在bh这一列有1、1、1、2、2、2现在需要改为1-1、1-2、1-3、2-1、2-2、2-3如何通过Python实现?...
如图在bh这一列有1、1、1、2、2、2现在需要改为1-1、1-2、1-3、2-1、2-2、2-3 如何通过Python实现?
展开
4个回答
展开全部
more bh.txt
1
1
1
1
2
2
2
3
3
3
3
3
4
4
#脚本文件
#!/usr/bin/env python
q=[]
with open('py4.txt') as f:
d=[i.strip() for i in f.readlines()]
[q.append("%s-%s" %(i,k)) for i in set(d) for k in range(1,d.count(i)+1)]
print sorted(q)
#输出结果
['1-1', '1-2', '1-3', '1-4', '2-1', '2-2', '2-3', '3-1', '3-2', '3-3', '3-4', '3-5', '4-1', '4-2']
最下面加上一个循环,输出可改变
for i in sorted(q):
print '%s,'%i,
#输出为
1-1, 1-2, 1-3, 1-4, 2-1, 2-2, 2-3, 3-1, 3-2, 3-3, 3-4, 3-5, 4-1, 4-2,
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
AiPPT
2024-09-19 广告
2024-09-19 广告
随着AI技术的飞速发展,如今市面上涌现了许多实用易操作的AI生成工具1、简介:AiPPT: 这款AI工具智能理解用户输入的主题,提供“AI智能生成”和“导入本地大纲”的选项,生成的PPT内容丰富多样,可自由编辑和添加元素,图表类型包括柱状图...
点击进入详情页
本回答由AiPPT提供
展开全部
做个函数就好:
buff={}
def autocode(k):
buff[k] = buff.get(k,0) + 1
return '{}-{}'.format(k, buff[k])
测试:
print(autocode(1))
print(autocode(1))
print(autocode(1))
print(autocode(2))
print(autocode(2))
print(autocode(2))
print(autocode(1))
print(autocode(1))
print(autocode(1))
输出结果:
1-1
1-2
1-3
2-1
2-2
2-3
1-4
1-5
1-6
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
l = [1,1,1,2,2,2]
new = ['%s-%s'%((i%3)+1, n) for i,n in enumerate(l)]
print l
print new
输出如下结果:
[1, 1, 1, 2, 2, 2]
['1-1', '2-1', '3-1', '1-2', '2-2', '3-2']
追问
和我的要求不太一样吧 我要求的输出结果是1-1、1-2、1-3、2-1、2-2、2-3
追答
看错题意了,改成这样就好了:
l = [1,1,1,2,2,2]
new = ['%s-%s'%(n,(i%3)+1) for i,n in enumerate(l)]
print l
print new
输出如下结果:
[1, 1, 1, 2, 2, 2]
['1-1', '1-2', '1-3', '2-1', '2-2', '2-3']
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
需要在excel中操作还是在文本文件中?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询