1. 学习g++能够读取什么格式的txt文件。

    读基本指令:

    >sprintf(filename,
    "doc_%d.txt",
    d);

    >fileptr
    =
    fopen(filename,
    "r");

    >while
    ((fscanf(fileptr,
    "%d ")
    !=
    EOF))

    > {fscanf(fileptr,
    "[%d,%d]",
    &s1,
    &s2);}

    fclose(fileptr);

    写基本指令:

    >fileptr
    =
    fopen("result_1.txt",
    "w");

    >fprintf(fileptr,
    "(%d)",
    x);

    >fprintf(fileptr,
    "\n");

    >fclose(fileptr);

具体的代码及要完成的简单任务描述如下:

// TestForReadTXT_Windows.cpp : 定义控制台应用程序的入口点。

//,读取doc_1.txt中的n行数据,并写入vector中,这里不进行运算,直接将xy坐标写回名为result_1.txt的文件中。

//数据在txt中的存放格式是3条轨迹以固定格式存储的轨迹数据

//5 [3,0](448,26,11)(447,26,13)(447,27,16)(447,28,17)(448,28,20)

//9 [0, 2](282, 101, 1436)(282, 102, 1437)(283, 102, 1440)(283, 101, 1442)(284, 101, 1445)(285, 101, 1447)(284, 101, 1448)(283, 101, 1451)(282, 101, 1455)

//3 [0,0](407,37,678)(406,37,682)(405,37,684)

//其中第一个代表元素个数,[]代表起止点,(x,y,t)代表轨迹信息

#include
"stdafx.h"

#include
<iostream>

#include
<vector>

using
namespace
std;

typedef
struct{

    int
x;

    int
y;

    size_t
t;

}
Point;

 

class
Trajectory{

public:

    //Trajectory();

    size_t
length;

    char
source;

    char
sink;

    vector<Point>
d_point;

};

int
_tmain(int
argc,
_TCHAR*
argv[])

{

    size_t
d,
i;

    int
length,
x,
y,
t,
s1,
s2,
numTrk
=
0;

    Point
p;

    Trajectory*
traj;

    vector<Trajectory>
TD;

    char
filename[100];

    FILE
*fileptr;

 

    printf("load data ...\n");

 

    for
(d
=
1;
d
<
2;
d++){

        //sprintf(filename, "trks_grand_ss8.txt");

        sprintf(filename,
"doc_%d.txt",
d);

        //sprintf(filename, "parkinglot_trk.txt");

        fileptr
=
fopen(filename,
"r");

 

        while
((fscanf(fileptr,
"%d ",
&length)
!=
EOF))//原始数据中的每行第一个数代表轨迹的长度

        {

        

            traj
=
new
Trajectory();

            fscanf(fileptr,
"[%d,%d]",
&s1,
&s2);//原始数据中的每行第2个代表source,sink点是否被观察

            /* traj->d_source=s1;

            traj->d_sink=s2;*/

            

            for
(i
=
0;
i
<
length;
i++){

                fscanf(fileptr,
"(%d,%d,%d)",
&x,
&y,
&t);

                p.x
=
x;
p.y
=
y;
p.t
=
t;

 

                traj->d_point.push_back(p);// (i, p, s1, s2);

 

            }

            

            fscanf(fileptr,
"\n");

            traj->sink
=
s1;

            traj->source
=
s2;

            traj->length
=
length;

            TD.push_back(*traj);

            //d_trajSet.push_back(*traj);

            //d_trajSet[numTrk].trkSource = s1;

            //d_trajSet[numTrk].trkSink = s2;

            //printf("cur TrkSource is %d, curTrkSink is %d. \n", d_trajSet[numTrk].trkSource,d_trajSet[numTrk].trkSink);

            //system( "pause ");

            

            numTrk++;

            delete
traj;

        }

        fclose(fileptr);

    }

    

    printf("%d trajectories are loaded. \n",
numTrk);

 

    fileptr
=
fopen("result_1.txt",
"w");

    for
(int
k
=
0;
k
<
numTrk;
k++){

    
 

    

        for
(int
w
=
0;
w
<
TD.at(k).length;
w++){

        

            fprintf(fileptr,
"(%d)",
TD.at(k).d_point.at(w).x);

        }

        

        fprintf(fileptr,
"\n");

        for
(int
w
=
0;
w
<
TD.at(k).length;
w++){

            

            fprintf(fileptr,
"(%d)",
TD.at(k).d_point.at(w).y);

        }

        fprintf(fileptr,
"\n");

 

    }

    fclose(fileptr);

    return
0;

}

写入result_1之后的结果如下:

 

(448)(447)(447)(447)(448)

(26)(26)(27)(28)(28)

(282)(282)(283)(283)(284)(285)(284)(283)(282)

(101)(102)(102)(101)(101)(101)(101)(101)(101)

(407)(406)(405)

(37)(37)(37)

 

程序在Ubuntu中的配置:需要多加一个在vc中包含于iostream中的头文件 #include<stdio.h>

在VC中用sprintf(filename,
"..//..//..//data/doc_%d.txt",
d);来表征上层目录。

Matlab 与 c++对txt 文档的读写格式的更多相关文章

  1. 用matlab查找txt文档中的关键字,并把关键字后面的数据存到起来用matlab处理

    用matlab查找txt文档中的关键字,并把关键字后面的数据存到起来用matlab处理 我测了一组数据存到txt文件中,是个WIFI信号强度文档,里面有我们需要得到的数据,有没用的数据,想用matla ...

  2. 将mat文件中的数据按要求保存到txt文档中(批处理)

    之前有个老朋友,让帮忙将一个mat中的数据重新保存到txt中,由于数据比较多需要用到批处理,之前弄过很多次,但每次一到要用的时候总是忘记怎么写了,现在记录一下,免得后面老是需要上网搜.这里先说一个比较 ...

  3. C# 将内容写入txt文档

    <1>  FileStream fs = new FileStream(@"D:\text.txt", FileMode.Append); StreamWriter s ...

  4. QTP操作txt文档

    QTP可以在txt文件(文本文件中读取数据) 首先创造一个文档对象 set fso = createObject("scripting.filesystemobject") 然后用 ...

  5. 利用IDL将一个txt文档拆分为多个

    测试.txt文档,每47行的格式相同,通过代码每47行存为一个txt,txt文档命名为其第一行数据. 代码如下: file='G:\data\测试.txt' openr,lun,file,/Get_L ...

  6. WebService 实现BS环境与BS环境传递参数,根据参数生成txt文档

    客户端: <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Client.as ...

  7. 将txt文档按行分割

    昨天遇到了一个需求,需要将txt文档按行分割,并指定了行数, 最近在用python,就在网上搜了一下,在参考了http://blog.csdn.net/zhang_red/article/detail ...

  8. 用C++向一个txt文档中写数据

    bool CMaked::WriteFileMake(CString filePath, const char *isChange) { ofstream file; //filePath为该txt文 ...

  9. 一个简易的Python爬虫,将爬取到的数据写入txt文档中

    代码如下: import requests import re import os #url url = "http://wiki.akbfun48.com/index.php?title= ...

随机推荐

  1. Jenkins的简单安装

    系统:CentOS release 6.5 (Final) 一. 安装JDK 1.1 查询系统是否已安装OpenJDK Centos系统默认会安装OpenJDK,首先检查系统是否安装有jdk并且是Op ...

  2. 【题解】有标号的DAG计数3

    [HZOI 2015] 有标号的DAG计数 III 我们已经知道了\(f_i\)表示不一定需要联通的\(i\)节点的dag方案,考虑合并 参考[题解]P4841 城市规划(指数型母函数+多项式Ln), ...

  3. $CF912E\ Prime\ Gift$ 二分+搜索

    正解:二分+搜索 解题报告: 传送门$QwQ$ 因为翻译真的很$umm$所以还是写下题目大意$QwQ$,就说给定一个大小为$n$的素数集合,求出分解后只含这些质数因子的第$K$小整数 考虑先把质数分两 ...

  4. JVM之GC回收信息详解

    一.-XX:+PrintGCDetails 打印GC日志 参数配置:-Xms10M -Xmx10M -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+Pr ...

  5. 【转】c#中数组赋值方法

    C#中数组复制有多种方法,数组间的复制 ,,,};int [] alias = pins; 这里出了错误,也是错误的根源,以上代码并没有出错,但是根本不是复制,因为pins和alias都是引用,存在于 ...

  6. 学习集合Collection_通用方法

    Collection 常用接口 集合List和Set通用的方法 public boolean add(E e) 添加对象到集合 public boolean remove(E e) 删除指定元素 pu ...

  7. 微信授权流程和JSSDK调用流程

    概念理解 业务域名:当前业务使用的是哪个网站,好处:设置业务域名后,在微信内访问该域名下页面时,不会被重新排版.不出现“防欺诈盗号,请误支付或输入qq密码”的提示,微信认为该域名是安全的,客户也不觉得 ...

  8. ES 服务器 索引、类型仓库基类 BaseESStorage

    /******************************************************* * * 作者:朱皖苏 * 创建日期:20180508 * 说明:此文件只包含一个类,具 ...

  9. 2019 ICCV、CVPR、ICLR之视频预测读书笔记

    2019 ICCV.CVPR.ICLR之视频预测读书笔记 作者 | 文永亮 学校 | 哈尔滨工业大学(深圳) 研究方向 | 视频预测.时空序列预测 ICCV 2019 CVP github地址:htt ...

  10. cf 450b 矩阵快速幂(数论取模 一大坑点啊)

    Jzzhu has invented a kind of sequences, they meet the following property: You are given x and y, ple ...