将dataframe中的ndarray存入csv后,出现省略号

了解如何使用to_csv方法避免长数组被省略的问题,通过转换为list确保数据完整保存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

``` import numpy as np import pymssql import pandas as pd import math def calculate_workday(): server = '100.00.00.00' database = 'D' username = 'x' password = '@' port = '1433' # 如果使用默认端口号(1433),则可以省略此步骤 # 连接数据库并执行查询 conn = pymssql.connect(server, user=username, password=password, database=database, port=port) query ="SELECT * FROM DLCH.dbo.CH_MainDt WHERE ((YWNRId >= 1 AND YWNRId <= 41) OR (YWNRId >= 85 AND YWNRId <= 97)) ORDER BY CreateTime" # 获取查询结果,将结果写入df csv_data = pd.read_sql_query(query, conn) conn.close() # 保证需要参与计算工期的列为数值 columns_to_convert = ['paraInt1', 'paraInt2', 'paraInt3', 'paraFloat1', 'paraFloat2', 'paraFloat5'] for column in columns_to_convert: csv_data[column] = pd.to_numeric(csv_data[column], errors='coerce') # 判断工期和工作量并将结果存入新的列中 def cal_workday(csv_data): csv_data['工期'] = '协商' csv_data['工作量'] = '' csv_data['工作量'] = csv_data['工作量'].astype(str) # 转化成字符串形式 # YWNRId=7 csv_data.loc[csv_data['YWNRId'] == '7', '工期'] = csv_data.loc[ csv_data['YWNRId'] == '7', 'paraFloat1'].apply( lambda x: 7 if x <= 50000 else min(7 + 2 * math.ceil((x - 50000) / 50000), 25) ) # YWNRId=16 csv_data.loc[csv_data['YWNRId'] == '16', '工期'] = csv_data.loc[ csv_data['YWNRId'] == '16', 'paraFloat1'].apply( lambda x: 10 if x <= 50000 else ( 12 if x <= 100000 else ( 15 if x <= 200000 else 15 + 3 * math.ceil((x - 200000) / 50000) ) ) ) return csv_data 应用计算结果 csv_data = cal_workday(csv_data) # 关键步骤:将计算结果合并回原DataFrame # 输出到CSV csv_data.to_csv('计算结果.csv', index=False, encoding='utf_8_sig') # 支持中文路径 print("文件已成功导出为 计算结果.csv")```将YWNRId类型: int64,先变为字符串,再执行cal_workday
最新发布
03-15
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值