如何将日期保存在二进制文件中,然后读取文件并打印
how to save dates in binary file then read the file and print it?
我编辑了它,我无法回答我自己的问题
// Cajero.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include "MiLib.h"
#include <time.h>
#include <string.h>
int Menu1();
void Baja(FILE* fp);
void Modificar(FILE* fp);
void Retiro(FILE* fp,FILE* as);
void Deposito(FILE* fp);
void ImprimeC(FILE* fp);
void ImprimeT(FILE* as);
void CuentaE(FILE* fp);
void CuentaN(CUENTA* Dar,FILE* fp);
void DarAlta(FILE* fp);
int Menu2();
void Tranfe(FILE* fp);
void Consu(FILE* fp);
int _tmain(int argc, _TCHAR* argv[])
{
CUENTA cuenta;
TRANSFE temp;
FILE *fptr,*asdf;
int opcion = 0,opcion2=0;
fptr = fopen("Cuentas.db", "r+b");
if(fptr == NULL) {
fptr = fopen("Cuentas.db", "w+b");
return 1;
}
asdf = fopen("Transferencias.db", "r+b");
if(asdf == NULL) {
asdf = fopen("Transferencias.db", "w+b");
return 1;
}
while(opcion < 6) {
opcion=0;
opcion = Menu1();
switch(opcion) {
case 1: {
Retiro(fptr,asdf);
break;
}
case 2: {
Deposito(fptr);
break;
} // fin del caso 2 borrar
case 3:{
Tranfe(fptr);
break;
}
case 4:{
Consu(fptr);
break;
}
case 5: {
opcion2=0;
opcion2=Menu2();
switch(opcion2){
case 1:{
DarAlta(fptr);
break;
}
case 2:{
Baja(fptr);
break;
}
case 3:{
Modificar(fptr);
break;
}
case 4:{
ImprimeC(fptr);
getche();
ImprimeT(asdf);
getch();
break;
}
}
break;
}
default : {
break;
}
}
}
fclose(fptr);
fclose(asdf);
return 0;
}
void ImprimeT(FILE* as){
TRANSFE temp;
system("cls");
printf(" L I S T A D E T R A N S F E R E N C I A Snn");
printf("Cuenta Dinero Movimiento Fecha n");
printf("------- ----------- ------------- --------------------n");
rewind(as);
do {
fflush (as);
fread( &temp, sizeof(TRANSFE), 1, as );
if( feof(as) ) break;
if (temp.baja == 0) {
printf("%d %f %s %sn",
temp.numero, temp.dinero, temp.movi,
asctime(&temp.timeinfo)); // pass address of struct tm to asctime
fflush (as);
}
} while(TRUE);
return;
}
void Baja(FILE* fp) {
int baja, nip ,existe = FALSE;
fpos_t Fpos;
CUENTA temp;
system("cls");
printf("nnn");
printf("ttOpcion de baja cuentan");
printf("ttCuenta a dar de baja -> ");
scanf("%d", &baja);
rewind(fp);
do {
fgetpos( fp, &Fpos );
fread( &temp, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break;
if(baja == temp.numero) {
printf("nttNIP ->");
scanf("%d",&nip);
if(nip == temp.nip) {
if(temp.baja == 0) {
temp.baja = 1; // lo marco como baja logica
fsetpos( fp, &Fpos );
fwrite( &temp, sizeof(CUENTA), 1, fp );
printf("nnCuenta: %d dado de BAJAn", temp.numero);
} else {
printf("ttEsta Cuenta ya fue dado de bajan");
}
existe = TRUE;
break; // salida del if
}else{
printf("nttNIP equivocado intente de nuevo");
getche();
Baja(fp);
}
}
} while( TRUE );
if(!existe) {
printf("ttLa cuenta no existe en el archivo");
getche();
return;
}
return;
}
void Modificar(FILE* fp){
int cuenta,nip=0,op=0, existe = FALSE;
char nombre[50];
fpos_t Fpos; // direccion del registro
CUENTA temp;
system("cls");
printf("nnn");
printf("ttOpcion de modificar cuentan");
printf("ttCuenta -> ");
scanf("%d", &cuenta);
rewind(fp);
do {
fgetpos( fp, &Fpos );
fread( &temp, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break;
if(cuenta == temp.numero) {
printf("nttNIP ->");
scanf("%d",&nip);
if(nip==temp.nip){
do{
system("cls");
printf("nnntt1.- Nombre");
printf("ntt2.- NIP");
printf("ntt3.- RFC");
printf("ntt4.- Regresar al menu");
printf("nnttQue desea modificar ->");
scanf("%d",&op);
system("cls");
switch(op){
case 1:{
printf("ntt Nuevo nombre ->");
scanf(" %[^n]",temp.nombre);
fsetpos( fp, &Fpos );
fwrite( &temp, sizeof(CUENTA), 1, fp );
printf("ntt Modificacion efectuada con exito");
break;
}
case 2:{
printf("nttNuevo NIP ->");
scanf("%d",&temp.nip);
fsetpos( fp, &Fpos );
fwrite( &temp, sizeof(CUENTA), 1, fp );
printf("nttModificacion efectuada con exito");
break;
}
case 3:{
printf("nttNuevo RFC ->");
scanf(" %[^n]",&temp.RFC);
fsetpos( fp, &Fpos );
fwrite( &temp, sizeof(CUENTA), 1, fp );
printf("nttModificacion efectuada con exito");
break;
}
default:{
return;
}
}
}while(op<4);
fsetpos( fp, &Fpos );
fwrite( &temp, sizeof(CUENTA), 1, fp );
}else{
printf("nttNIP equivocado intente de nuevo");
getche();
Modificar(fp);
}
existe = TRUE;
break; // salida del if
}
} while( TRUE );
if(!existe) {
printf("ttLa cuenta no existe en el archivo");
getch();
return;
}
return;
}
void Retiro(FILE* fp,FILE* as){
int cuenta,nip=0, existe = FALSE;
float retiro=0.0,saldoactual=0.0;
TRANSFE transfe;
time_t rawtime;
struct tm * timeinfo;
fpos_t Fpos;
CUENTA temp;
system("cls");
printf("nnn");
printf("ttOpcion de retiro a cuentan");
printf("ttCuenta -> ");
scanf("%d", &cuenta);
rewind(fp);
do {
fgetpos( fp, &Fpos );
fread( &temp, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break;
if(cuenta == temp.numero) {
printf("nttNIP ->");
scanf("%d",&nip);
if(nip==temp.nip){
printf("nttSaldo actual-> %f",temp.dinero);
printf("nttCifra a retirar->");
scanf("%f",&retiro);
saldoactual=(float)temp.dinero-retiro;
if(saldoactual<0.0){
printf("Insuficientes fondos");
getch();
Retiro(fp,as);
}else{
temp.dinero=saldoactual;
fsetpos( fp, &Fpos );
fwrite( &temp, sizeof(CUENTA), 1, fp );
printf("nttRetiro efectuado con exito");
transfe.numero=temp.numero;
transfe.baja=temp.baja;
transfe.dinero=retiro;
time ( &rawtime );
transfe.timeinfo = *localtime ( &rawtime ); // copy into struct tm
strncpy(transfe.movi, "retiro", MAXLEN); // copy into array
fwrite(&transfe,sizeof(TRANSFE),1,as);
getch();
return;
}
}else{
printf("NIP equivocado intente de nuevo");
getche();
Retiro(fp,as);
}
existe = TRUE;
break;
}
} while( TRUE );
if(!existe) {
printf("ttLa cuenta no existe en el archivo");
getch();
return;
}
return;
}
void Deposito(FILE* fp){
int cuenta,nip=0, existe = FALSE;
float deposito;
fpos_t Fpos; // direccion del registro
CUENTA temp;
system("cls");
printf("nnn");
printf("ttOpcion de deposito a cuentan");
printf("ttCuenta -> ");
scanf("%d", &cuenta);
rewind(fp);
do {
fgetpos( fp, &Fpos );
fread( &temp, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break;
if(cuenta == temp.numero) {
printf("nttNIP ->");
scanf("%d",&nip);
if(nip==temp.nip){
printf("nttSaldo actual-> %f",temp.dinero);
printf("nttCifra a depositar->");
scanf("%f",&deposito);
deposito=temp.dinero+deposito;
temp.dinero=deposito;
fsetpos( fp, &Fpos );
fwrite( &temp, sizeof(CUENTA), 1, fp );
printf("nttDeposito efectuado con exito");
}else{
printf("NIP equivocado intente de nuevo");
getche();
Deposito(fp);
}
existe = TRUE;
break; // salida del if
}
} while( TRUE );
if(!existe) {
printf("ttLa cuenta no existe en el archivo");
getche();
return;
}
return;
}
void ImprimeC(FILE* fp) {
CUENTA temp;
system("cls"); // ordena limpiar la pantalla
printf(" L I S T A D E C U E N T A Snn");
printf("Cuenta Nombre Dinero RFC n");
printf("------- -------------------- ------------- --------------------n");
rewind(fp);
do {
fread( &temp, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break; // salida del while
if(temp.baja == 0) {
printf("%7d %-20s %9.2f %-20sn", temp.numero, temp.nombre, temp.dinero,temp.RFC);
} // fin frl if
} while(TRUE); // fin del for que muestra los datos en pantalla
return;
}
void CuentaE(FILE* fp){
int cuenta,nip=0, existe = FALSE;
float deposito;
fpos_t Fpos; // direccion del registro
CUENTA temp;
system("cls");
printf("nnn");
printf("ttDar de alta cuenta existenten");
printf("ttCuenta -> ");
scanf("%d", &cuenta);
rewind(fp);
do {
fgetpos( fp, &Fpos );
fread( &temp, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break;
if(cuenta == temp.numero) {
printf("nttNIP ->");
scanf("%d",&nip);
if(nip==temp.nip){
temp.baja=0;
fsetpos( fp, &Fpos );
fwrite( &temp, sizeof(CUENTA), 1, fp );
printf("nttCuenta dada de alta con exito");
}else{
printf("NIP equivocado intente de nuevo");
getche();
DarAlta(fp);
}
existe = TRUE;
break; // salida del if
}
} while( TRUE );
if(!existe) {
printf("ttLa cuenta no existe en el archivo");
getch();
return;
}
return;
}
int Menu1(){
int op;
system("cls");
printf("nnntt1.-Retiro de cuenta");
printf("ntt2.-Depositar a cuenta");
printf("ntt3.-Transferencia");
printf("ntt4.-Colsulta de saldo");
printf("ntt5.-Opciones de cuentas");
printf("ntt6.-Salir");
printf("nnttOpcion----->");
scanf("%d",&op);
system("cls");
return op;
}
void CuentaN(CUENTA* Dat,FILE* fp){
int existe=FALSE;
rewind(fp);
system("cls");
CUENTA temp;
printf("nnn");
printf("ttNumero -> ");
scanf("%d", &Dat->numero);
do {
fread( &temp, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break; // salida del while
if(temp.numero==Dat->numero){
printf("nttCuenta existente por favor elegir otro numero de cuenta");
getche();
existe=TRUE;
return;
}
} while(TRUE);
if(!existe){
printf("ttNIP -> ");
scanf("%d", &Dat->nip);
printf("ttNombre -> ");
scanf(" %[^n]", &Dat->nombre);
printf("ttDeposito -> ");
scanf("%f", &Dat->dinero);
printf("ttRFC -> ");
scanf(" %[^n]", &Dat->RFC);
printf("n");
Dat->baja = 0;
printf("nttCuenta creada con exito");
getche();
}else{
return;
}
do {
fread( &temp, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break;
} while(TRUE);
return;
}
void DarAlta(FILE* fp){
int op;
CUENTA cuenta;
system("cls");
printf("nnntt1.- Dar de alta cuenta existente");
printf("ntt2.- Dar de alta cuenta inexsistente");
printf("ntt3.- Regresar al menu");
printf("nnttQue desea modificar ->");
scanf("%d",&op);
switch(op){
case 1:{
CuentaE(fp);
break;
}
case 2:{
CuentaN(&cuenta,fp);
fwrite( &cuenta, sizeof(CUENTA), 1, fp);
break;
}
default:{
return;
}
}
system("cls");
return;
}
int Menu2(){
int op2;
system("cls");
printf("nnntt1.-Dar de alta cuenta");
printf("ntt2.-Dar de baja cuenta");
printf("ntt3.-Modificar cuenta");
printf("ntt4.-Listar cuentas");
printf("ntt5.-Regresar al menu anterior");
printf("nnttOpcion----->");
scanf("%d",&op2);
system("cls");
return op2;
}
void Tranfe(FILE* fp){
int cuenta,cuentatr,nip, existe = FALSE,existetr =FALSE;
float trans=0.0,saldon;
fpos_t Fpos,Fpostr; // direccion del registro
CUENTA temp,temp2;
system("cls");
printf("nnn");
printf("ttOpcion de transferencian");
printf("ttCuenta que tranfiere -> ");
scanf("%d", &cuenta);
rewind(fp);
do{
fgetpos( fp, &Fpos );
fread( &temp, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break;
if(temp.numero==cuenta){
printf("nttNIP ->");
scanf("%d",&nip);
if(temp.nip==nip){
printf("nttSaldo actual-> %f",temp.dinero);
printf("nttDinero a transferir ->");
scanf("%f",&trans);
if(temp.dinero-trans>=0){
temp.dinero=temp.dinero-trans;
}else{
printf("nnttCuenta con insuficiente dinero");
getche();
Tranfe(fp);
}
printf("nnttCuenta a transferir ->");
scanf("%d",&cuentatr);
rewind(fp);
do{
fgetpos(fp,&Fpostr);
fread( &temp2, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break;
if(temp2.numero==cuentatr){
temp2.dinero=temp2.dinero+trans;
fsetpos(fp,&Fpostr);
fwrite( &temp2, sizeof(CUENTA), 1, fp );
fsetpos(fp,&Fpos);
fwrite( &temp, sizeof(CUENTA), 1, fp );
printf("nnttTransferencia con exito");
existetr = TRUE;
return;
}
}while(TRUE);
if(!existetr) {
printf("ttLa cuenta no existe en el archivo");
getche();
Tranfe(fp);
}
}else{
printf("nntNIP equivocado");
getche();
Tranfe(fp);
}
existe = TRUE;
break; // salida del if
}
}while(TRUE);
if(!existe) {
printf("ttLa cuenta no existe en el archivo");
getche();
return;
}
return;
}
void Consu(FILE* fp){
int cuenta,nip=0, existe = FALSE;
float deposito;
fpos_t Fpos; // direccion del registro
CUENTA temp;
system("cls");
printf("nnn");
printf("ttOpcion de consulta de saldon");
printf("ttCuenta -> ");
scanf("%d", &cuenta);
rewind(fp);
do {
fgetpos( fp, &Fpos );
fread( &temp, sizeof(CUENTA), 1, fp );
if( feof(fp) ) break;
if(cuenta == temp.numero) {
printf("nttNIP ->");
scanf("%d",&nip);
if(nip==temp.nip){
printf("nttSaldo actual-> %f",temp.dinero);
getche();
}else{
printf("NIP equivocado intente de nuevo");
getche();
Consu(fp);
}
existe = TRUE;
break; // salida del if
}
} while( TRUE );
if(!existe) {
printf("ttLa cuenta no existe en el archivo");
getche();
return;
}
return;
}
不能有意义地保存和加载指针。在写入之前,请更改指向结构值或数组的所有指针。
声明
#define MAXLEN 100 // set to maximum length you expect movi to need
typedef struct {
int numero;
float dinero;
int baja;
struct tm timeinfo; // struct tm, not pointer to struct tm
char movi[MAXLEN]; // character array, not pointer
} TRANSFE;
写入
transfe.numero=temp.numero;
transfe.baja=temp.baja;
transfe.dinero=retiro;
time ( &rawtime );
transfe.timeinfo = *localtime ( &rawtime ); // copy into struct tm
strncpy(transfe.movi, "retiro", MAXLEN); // copy into array
fwrite(&transfe,sizeof(TRANSFE),1,as);
读取
do {
fflush (as);
fread( &temp, sizeof(TRANSFE), 1, as );
if( feof(as) ) break;
if (temp.baja == 0) {
printf("%d %f %s %sn",
temp.numero, temp.dinero, temp.movi,
asctime(&temp.timeinfo)); // pass address of struct tm to asctime
fflush (as);
}
} while(TRUE);
你可能也不需要这些电话。
更多想法:
我不清楚fread之后的fef是否会可靠地检测到eof而不丢弃最后一条记录。我建议您从更改所有循环
do {
fflush (as);
fread( &temp, sizeof(TRANSFE), 1, as );
if( feof(as) ) break;
// do something
} while(TRUE);
改为使用此:
while (TRUE) {
if (fread( &temp, sizeof(TRANSFE), 1, as ) != 1)
break;
// do something
}
此外,如果您更改了TRANSFE的声明,则先前写入的数据文件将不兼容。删除它们并创建新的空文件。
如果您的文件中有一些已知的好数据,它将帮助您进行调试。您可以使用类似的东西将测试数据填充到文件中,这样您就可以使用它进行调试
FILE *fcuentas = fopen("Cuentas.db", "w+b");
for (int i=1; i<10; i++)
{
CUENTA test = {};
test.baja = i*100 + 1;
test.dinero = i*100 + 2;
test.nip = i*100 + 3;
strcpy(test.nombre, "test nombre");
test.numero = i*100 + 5;
strcpy(test.RFC,"test RFC");
fwrite( &test, sizeof(CUENTA), 1, fcuentas );
}
fclose(fcuentas);
FILE *ftransferencias = fopen("Transferencias.db", "w+b");
for (int i=1; i<10; i++)
{
TRANSFE test = {};
test.baja = i*100 + 1;
test.dinero = i*100 + 2;
strcpy(test.movi, "test movi");
test.numero = i*1000 + 5;
time_t rawtime;
time ( &rawtime );
test.timeinfo = *localtime ( &rawtime ); // copy into struct tm
fwrite( &test, sizeof(TRANSFE), 1, ftransferencias );
}
fclose(ftransferencias);
相关文章:
- C++:如何读取分离变量,然后读取向量
- 如何从文件中读取值,然后使用它们来初始化 2D 数组C++
- 我编写了以下代码来读取C++矩阵,然后打印其行和列.我收到此错误
- C++,从文件读取到结构,然后读取到向量(结构被推入向量太多次,而不仅仅是一次)
- 我正在尝试从输入文件中读取,然后使用它们的子字符串比较字符串的特定部分
- 需要从存档中读取一行文本.txt直到找到"hhh",然后转到下一行
- 读取一组用户输入,按升序排序,然后打印结果
- 从文本文件读取,然后将项目存储到列表中
- 从文本文件中读取并输入到数组结构中,然后显示读取的数据C++
- C++读取大文件并将其保存到字符串中,然后删除特定的随机单词
- 如何将QGraphicsItem QList保存到文件中,然后读取它?Qt c++
- 将 bimap 写入二进制文件,然后读取它
- 如果没有数据,则创建一个包含数据的文本文件,然后读取它以检索数据
- 如何重复写入,然后读取,在管道中,就像打字到"cat | tr a-z A-Z"一样
- Qt C++ 如何将加密文本的QByteArray保存到文件中,然后读取并格式化为QByteArray
- C++写入文件,然后读取它
- 在C++的文本文件中读取数字,然后读取字母
- 如何将日期保存在二进制文件中,然后读取文件并打印
- 运行文件直到*字符串*,然后读取列直到*没有十进制*
- 在C++中读取一些整数,然后读取一行文本