基于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 相关文章推荐
PyQt5主窗口动态加载Widget实例代码
Feb 07 Python
python二维列表一维列表的互相转换实例
Jul 02 Python
Python的条件表达式和lambda表达式实例
Jan 31 Python
Django 静态文件配置过程详解
Jul 23 Python
python正则表达式匹配不包含某几个字符的字符串方法
Jul 23 Python
pytorch 在网络中添加可训练参数,修改预训练权重文件的方法
Aug 17 Python
使用Python matplotlib作图时,设置横纵坐标轴数值以百分比(%)显示
May 16 Python
PyQt5.6+pycharm配置以及pyinstaller生成exe(小白教程)
Jun 02 Python
在pytorch中动态调整优化器的学习率方式
Jun 24 Python
解决django migrate报错ORA-02000: missing ALWAYS keyword
Jul 02 Python
python3.5的包存放的具体路径
Aug 16 Python
简单了解Python字典copy与赋值的区别
Sep 16 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
thinkPHP统计排行与分页显示功能示例
2016/12/02 PHP
Laravel框架实现文件上传的方法分析
2019/09/29 PHP
javascript显示隐藏层比较不错的方法分析
2008/09/30 Javascript
JavaScript(js)设置默认输入焦点(focus)
2012/12/28 Javascript
用js+iframe形成页面的一种遮罩效果的具体实现
2013/12/31 Javascript
jquery实现拖拽调整Div大小
2015/01/30 Javascript
原生js的数组除重复简单实例
2016/05/24 Javascript
浅谈toLowerCase和toLocaleLowerCase的区别
2016/08/15 Javascript
JS基于面向对象实现的拖拽功能示例
2016/12/20 Javascript
简单的jQuery拖拽排序效果的实现(增强动态)
2017/02/09 Javascript
React.js中常用的ES6写法总结(推荐)
2017/05/09 Javascript
打通前后端构建一个Vue+Express的开发环境
2018/07/17 Javascript
JavaScript中为事件指定处理程序的五种方式分析
2018/07/27 Javascript
npm 常用命令详解(小结)
2019/01/17 Javascript
vue项目中锚点定位替代方式
2019/11/13 Javascript
[00:02]DOTA2新版本使用PA至宝后暴击展示
2014/11/19 DOTA
详解Python3.1版本带来的核心变化
2015/04/07 Python
python中文件变化监控示例(watchdog)
2017/10/16 Python
python中计算一个列表中连续相同的元素个数方法
2018/06/29 Python
利用python打开摄像头及颜色检测方法
2018/08/03 Python
python斐波那契数列的计算方法
2018/09/27 Python
Python线性拟合实现函数与用法示例
2018/12/13 Python
Pycharm之快速定位到某行快捷键的方法
2019/01/20 Python
pip安装tensorflow的坑的解决
2020/04/19 Python
python爬虫容易学吗
2020/06/02 Python
利用纯css3实现的文字亮光特效的代码演示
2014/11/27 HTML / CSS
请问如下代码执行后a和b的值分别是什么
2016/05/05 面试题
副总经理任命书
2014/06/05 职场文书
市场调查策划方案
2014/06/10 职场文书
医学专业大学生求职信
2014/07/12 职场文书
课外访万家心得体会
2014/09/03 职场文书
党的群众路线教育实践活动心得体会范文
2014/11/05 职场文书
2015感人爱情寄语
2015/02/26 职场文书
离婚被告答辩状
2015/05/22 职场文书
2015秋季田径运动会广播稿
2015/08/19 职场文书
学校扫黄打非工作总结
2015/10/15 职场文书