基于python批量处理dat文件及科学计算方法详解


Posted in Python onMay 08, 2018

摘要:主要介绍一些python的文件读取功能,文件内容修改,文件名后缀更改等操作。

批处理文件功能

import os
path1 = 'C:\\Users\\awake_ljw\\Documents\\python for data analysis\\test1'
path2 = 'C:\\Users\\awake_ljw\\Documents\\python for data analysis\\test2'
filelist = os.listdir(path1)
for files in filelist:
 Olddir = os.path.join(path1,files)
 filename = os.path.splitext(files)[0]
 filetype = os.path.splitext(files)[1]
 print Olddir
 file_test = open(Olddir,'r')
 Newdir = os.path.join(path2,str(filename)+'.csv')
 print Newdir
 file_test2 = open(Newdir,'w')
 for lines in file_test.readlines():
 strdata = ",".join(lines.split('\t'))
 file_test2.write(strdata)
 file_test.close()
 file_test2.close()

os模块是python最基础的模块之一,一般用于文件处理等操作。上面这段代码主要就是将dat文件转化为csv文件,同时保证csv可读。一般txt文件不能通过直接改后缀改变呈csv文件格式,一般会造成文件不可读。csv文件一般通过逗号分隔文本,数据处理起来较得心应手,可以直接改后缀得到xlsx文件,一般excel也可读。

科学计算

matlab作为一门科学计算编程语言,在科学计算的应用实在广泛,包括webread等强大的函数用起来十分顺手,但matlab是商业软件,并不免费。其实,python在科学计算效率或函数库功能包括其绘图功能、图像处理都很强大,(相比matlab,python的调色板更出色)。以下列举一些数据文件读取,绘图的一些基本操作作为参考。

数据提取及绘图

#数据提取
import os 
import pandas as pd
import numpy as np
number = -1;
sudu=np.zeros(5247*5,dtype=float).reshape(5247,5)
for files in filelist1:
 number +=1
 data = pd.read_csv(str(number+1)+'a.csv')
 sudu[:,number]=data['velocity']
 x = data['x']
 y = data['y']
a = sudu[0:5184,0].reshape(81,64)
%matplotlib inline
import matplotlib.pyplot as plt
extent = [np.min(x),np.max(x),np.min(y),np.max(y)]
plt.subplot(231)
u0 = sudu[0:5184,0].reshape(81,64)
plt.imshow(u0,extent=extent,origin='lower')
plt.subplot(232)
u1 = sudu[0:5184,1].reshape(81,64)
plt.imshow(u1,extent=extent,origin='lower')
plt.subplot(233)
u2 = sudu[0:5184,2].reshape(81,64)
plt.imshow(u2,extent=extent,origin='lower')
plt.subplot(234)
u3 = sudu[0:5184,3].reshape(81,64)
plt.imshow(u3,extent=extent,origin='lower')
#plt.axis("equal")
plt.subplot(235)
u4 = sudu[0:5184,4].reshape(81,64)
plt.imshow(u4,extent=extent,origin='lower')
plt.subplot(236)
u5 = sudu[0:5184,4].reshape(81,64)
plt.imshow(u5,extent=extent,origin='lower')
#contour
cs = plt.contour(u5, 20,extent = extent)
plt.xlim(-0.8,0.8)
plt.ylim(0.6,2.2)
plt.axis('equal')

基于python批量处理dat文件及科学计算方法详解

基于python批量处理dat文件及科学计算方法详解

python的科学计算功能与matlab及其相似,python有几点不同在于

1.python有元组的数据类型,元组不同于列表,元组不可更改

2.python的数据检索使用[]

总而言之,python的数据形式及其丰富。

numpy以及pandas是python用于数据处理的两个库,具体使用方法主要推荐python科学计算这本书。matplotlib用于绘图,刚也说了,其调色板很厉害哦,图像质量不错。

预告:代码运行环境均为jupyter notebook,简直神器一般的存在,网上搭建的资料也太多。

以上这篇基于python批量处理dat文件及科学计算方法详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
跟老齐学Python之dict()的操作方法
Sep 24 Python
Python多线程、异步+多进程爬虫实现代码
Feb 17 Python
详解python进行mp3格式判断
Dec 23 Python
浅谈Python用QQ邮箱发送邮件时授权码的问题
Jan 29 Python
Pandas过滤dataframe中包含特定字符串的数据方法
Nov 07 Python
利用python GDAL库读写geotiff格式的遥感影像方法
Nov 29 Python
使用python的pexpect模块,实现远程免密登录的示例
Feb 14 Python
Numpy对数组的操作:创建、变形(升降维等)、计算、取值、复制、分割、合并
Aug 28 Python
Django 框架模型操作入门教程
Nov 05 Python
python numpy生成等差数列、等比数列的实例
Feb 25 Python
python生成大写32位uuid代码
Mar 03 Python
Python代码需要缩进吗
Jul 01 Python
使用Python通过win32 COM实现Word文档的写入与保存方法
May 08 #Python
Ubuntu下使用python读取doc和docx文档的内容方法
May 08 #Python
儿童编程python入门
May 08 #Python
解决python大批量读写.doc文件的问题
May 08 #Python
python在每个字符后添加空格的实例
May 07 #Python
Pycharm在创建py文件时,自动添加文件头注释的实例
May 07 #Python
python 读取DICOM头文件的实例
May 07 #Python
You might like
模仿OSO的论坛(四)
2006/10/09 PHP
PHP的cURL库功能简介 抓取网页、POST数据及其他
2011/04/07 PHP
php addslashes及其他清除空格的方法是不安全的
2012/01/25 PHP
PHP微信红包生成代码分享
2016/10/06 PHP
PHP缩略图生成和图片水印制作
2017/01/07 PHP
ExtJS 2.0实用简明教程 之Border区域布局
2009/04/29 Javascript
基于jquery的仿百度的鼠标移入图片抖动效果
2010/09/17 Javascript
nodejs的10个性能优化技巧
2014/07/15 NodeJs
jquery获取节点名称
2015/04/26 Javascript
Node.js开启Https的实践详解
2016/10/25 Javascript
vue内置组件transition简单原理图文详解(小结)
2018/07/12 Javascript
Angular中的ng-template及angular 使用ngTemplateOutlet 指令的方法
2018/08/08 Javascript
json数据格式常见操作示例
2019/06/13 Javascript
react的hooks的用法详解
2020/10/12 Javascript
vue el-upload上传文件的示例代码
2020/12/21 Vue.js
[02:51]2014DOTA2国际邀请赛 IG战队官方纪录片
2014/07/21 DOTA
Windows下PyMongo下载及安装教程
2015/04/27 Python
Python操作使用MySQL数据库的实例代码
2017/05/25 Python
Flask框架信号用法实例分析
2018/07/24 Python
python3爬虫怎样构建请求header
2018/12/23 Python
基于python实现高速视频传输程序
2019/05/05 Python
Python 根据日志级别打印不同颜色的日志的方法示例
2019/08/08 Python
python实现的爬取电影下载链接功能示例
2019/08/26 Python
CSS3教程(6):创建网站多列
2009/04/02 HTML / CSS
使用before和:after伪类制作css3圆形按钮
2014/04/08 HTML / CSS
CSS3实现酷炫的3D旋转透视效果
2019/11/21 HTML / CSS
如何做好总经理助理
2013/11/12 职场文书
咖啡馆创业计划书
2014/01/26 职场文书
建筑院校毕业生求职信
2014/06/13 职场文书
老人节标语大全
2014/10/08 职场文书
2014年接待工作总结
2014/11/26 职场文书
总经理岗位职责
2015/02/04 职场文书
行政复议决定书
2015/06/24 职场文书
中国梦宣传标语口号
2015/12/26 职场文书
python实现腾讯滑块验证码识别
2021/04/27 Python
PyTorch 如何自动计算梯度
2021/05/23 Python