python从oracle表中读出一列数字并进行分段再存到txt文本中

话不多说,直接上脚本代码。代码不规范仅做记录使用

import cx_Oracle
import pandas as pd
import matplotlib.pyplot as plt
import datetime
import xlwt

conn = cx_Oracle.connect('sys/root@127.0.0.1:1521/orcl')
# 操作游标
cursor = conn.cursor()
result = cursor.execute(r"select column from table order by xxx")

# 一次读出所有内容到内存中,性能较差
all_data = cursor.fetchall()
# 给列取上名字
chart = pd.DataFrame(all_data, columns=['one'])
# 用数组去接收分组之后的值
# chart['one']//5*5 表示数字每五个分一组
ls = []
# 整句表示的是对取出来的整列数字进行分组统计,算出每一组的占比
ls = chart.groupby(chart['one']//5*5).count() / len(chart)
print(ls['one'])

# 表示将整列数字分组之后的占比存到txt中
text = chart.groupby(chart['one']//5*5).count() / len(chart)
text.to_csv('point.txt', sep='\t', index=False)

cursor.close()
conn.close()

值得注意的是:
1 直接对pandas(DataFrame)进行打印的时候,虽然只有一列数字,但是在命令行中会出现两列数字。类似:

100	0.11123
105	0.111111
110	0.222222

但是存到txt文本后,只有

0.11123
0.111111
0.222222

2 chart[‘one’]//5*5是两个斜杠

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值