PDA

View Full Version : programma in C


marfer3
03-09-2004, 20:07
Stavo risolvendo il testo di questo problema con il seguente programma che però mi da' qualche problemuccio: qualcuno di voi mi darebbe una mano?
le funzioni fread mi danno come valore di ritorno 0. Perchè???
Grazie.

/*
Su un file binario (super.dat) sono stati registrati i prodotti in vendita in un negozio
di articoli sportivi.
Ogni articolo è caratterizzato da un codice alfanumerico univoco, una breve descrizione, il prezzo e la marca.
Tale file è ordinato in ordine crescente rispetto al codice articolo.
Impostare una procedura, guidata da menù,che preveda le seguenti opzioni:
1- dato un codice articolo, aumentare il suo prezzo del 2%
2- aumentare i prezzi di tutti gli articoli del 20%
3- stampare tutti gli articoli della stessa marca data in input
4- su un file ASCII (acquisto.txt) sono stati registrati i codici degli articoli acquistati da un cliente, stanmpare il

totale da pagare.
5- fine elaborazione
*/
#include "stdio.h"
struct sprod
{
char codice[10];
char descr[100];
float prezzo;
char marca[15];
};
void aggiungiprodotto(void);
int aumentacodice(char *cod);
int aumentatutti(void);
float prezzocodice(char *cod);
float calcolatotale();
void main(void)
{
int scelta;
char codicer[10];
char marcar[15];
do
{
clrscr();
printf("0-Aggiungere nuovo prodotto\n");
printf("1-dato un codice articolo, aumentare il suo prezzo del 20%\n");
printf("2-Aumentare i prezzi di tutti gli articoli del 20%\n");
printf("3-Stampare tutti gli articoli della stessa marca data in input\n");
printf("4-stampare il totale da pagare\n");
printf("5-Uscita\n");
printf("Scegli: ");
scanf("%d",&scelta);
fflush(stdin);
switch(scelta)
{
case 0:
aggiungiprodotto();
break;
case 1:
printf("Inserire codice da modificare: ");
gets(codicer);
if(aumentacodice(codicer))
printf("\nPrezzo modificato");
else
printf("\nCodice non trovato");
getch();
break;
case 2:
if(aumentatutti())
printf("\nPrezzi modificati");
else
printf("\nNessun prodotto trovato");
getch();
break;
case 3:
printf("Inserire marca da visualizzare: ");
gets(marcar);
if(visualizzamarca(marcar)==0)
printf("\nNessun prodotto trovato");

getch();
break;
case 4:
printf("\nIl totale da pagare e' : %f",calcolatotale());
getch();
break;
case 5:
break;
default:
printf("Scelta errata");
}
}while(scelta!=5);
}
void aggiungiprodotto(void)
{
struct sprod prod;
FILE *fp;
int temp;
fp=fopen("super.dat","a");
printf("Inserire codice: ");
gets(prod.codice);
printf("Inserire descrizione: ");
gets(prod.descr);
printf("Inserire prezzo: ");
scanf("%f",&prod.prezzo);
fflush(stdin);
printf("Inserire marca: ");
gets(prod.marca);
temp=fwrite(&prod,sizeof(struct sprod),1,fp);
fclose(fp);
}
int aumentacodice(char *cod)
{
struct sprod prod;
FILE *fp;
int n,trovato=0,pos;
fp=fopen("super.dat","r+");
for (;;)
{
pos=ftell(fp);
n=fread(&prod,sizeof(struct sprod),1,fp); // ritorna sempre 0
if (n==0) break;
if(strcmp(prod.codice,cod)==0)
{
trovato=1;
prod.prezzo=prod.prezzo*1.2;
fseek(fp,pos,0);
fwrite(&prod,sizeof(struct sprod),1,fp);
break;
}
}
fclose(fp);
return trovato;
}
//--------------------------------------------
//funzione parzialmente non funzionante, modifica solo il primo record
int aumentatutti(void)
{
struct sprod prod;
FILE *fp;
int n,trovato=0,pos,temp1,temp2,temp3;
fp=fopen("super.dat","r+");
for (;;)
{
pos=ftell(fp);
n=fread(&prod,sizeof(struct sprod),1,fp);
temp1=ftell(fp);
if (n==0) break;
trovato=1;
prod.prezzo=prod.prezzo*1.2;
fseek(fp,pos,0);
temp2=ftell(fp);
fwrite(&prod,sizeof(struct sprod),1,fp);
temp3=ftell(fp);
}
fclose(fp);
return trovato;
}
//------------------------------------------------------
int visualizzamarca(char *marca)
{
struct sprod prod;
FILE *fp;
int n,trovato=0;
fp=fopen("super.dat","r");
for (;;)
{
n=fread(&prod,sizeof(struct sprod),1,fp);
if (n==0) break;
if(strcmp(prod.marca,marca)==0)
{
trovato++;
printf("\n%s %s %f %s",prod.codice,prod.descr,prod.prezzo,prod.marca);
}
}
fclose(fp);
return trovato;
}
//--------------------------------------
float prezzocodice(char *cod)
{
struct sprod prod;
FILE *fp;
int n,trovato=0,pos;
fp=fopen("super.dat","r+");
for (;;)
{
pos=ftell(fp);
n=fread(&prod,sizeof(struct sprod),1,fp);
if (n==0) break;
if(strcmp(prod.codice,cod)==0)
{
fclose(fp);
return prod.prezzo;
break;
}
}
fclose(fp);
return 0;
}
float calcolatotale()
{
FILE *fp;
float totale=0;
char cod[10];
fp=fopen("acquisto.txt","r");
while(fscanf(fp,"%s",cod)!=-1)
totale=totale+prezzocodice(cod);
fclose(fp);
return totale;
}

Fenomeno85
04-09-2004, 11:08
vedere dei clicli for messi così fanno paura :doh:

allora:

1) fai un controllo sul puntatore fp
2) non usare clrscr dato che è solo una particolarità del compilatore Borland

allora:

1) incominciamo a togliere qualche possibile problema di apertura del file


if ((fp=fopen("super.dat", "a"))==NULL){
return;
}


2) usare dei cicli for messi in questo modo for(;;) fanno molto da grezzo e poi non è molto bello se si cerca di fare almeno un pò il programmatore ;). In questo caso siccome si deve scorrere un file usa questo metodo


while (!feof(fp)){
fread(prod,sizeof(prod),1,fp);
if (!feof(fp){
----- codice ----
}
}


adesso non ho tempo per modificare il codice e compilarlo ... se va bene oggi pomeriggio ci provo

~§~ Sempre E Solo Lei ~§~

Fenomeno85
04-09-2004, 20:24
domanda ma come ti faceva a funzionare se ci sono errori e non hai incluso delle librerie?! :mbe:

~§~ Sempre E Solo Lei ~§~

Fenomeno85
04-09-2004, 22:40
ammazzate corretto tutto tranne la parte dei file di testo che non li ho mai usati. Se c'è qualche anima pia che ha qualche info su come utilizzarli mi fa un piacere.
ps: l'ultima funzione sui file non l'ho toccata

pps: qualcuno avrebbe fatto diversamente??


#include <stdio.h>
#include <conio.h>
#include <string.h>

struct sprod
{
char codice[10];
char descr[100];
float prezzo;
char marca[15];
};

void aggiungiprodotto();
int aumentacodice(char *cod);
int aumentatutti();
float prezzocodice(char *cod);
float calcolatotale();
int visualizzamarca(char *marca);
void visualizza_file ();

void main()
{
int scelta;
char codicer[10];
char marcar[15];
do
{
printf("0-Aggiungere nuovo prodotto\n");
printf("1-dato un codice articolo, aumentare il suo prezzo del 20%\n");
printf("2-Aumentare i prezzi di tutti gli articoli del 20%\n");
printf("3-Stampare tutti gli articoli della stessa marca data in input\n");
printf("4-stampare il totale da pagare\n");
printf("5-se vuoi stampare a video tutto il file\n");
printf("6-stampare il prezzo dato un codice\n");
printf("7-Uscita\n");
printf("Scegli: ");
scanf("%d",&scelta);
fflush(stdin);
switch(scelta)
{
case 0:
aggiungiprodotto();
break;
case 1:
printf("Inserire codice da modificare: ");
gets(codicer);
fflush(stdin);
if(aumentacodice(codicer)) {
printf("\nPrezzo modificato");
break;
}
else {
printf("\nCodice non trovato\n\n");
break;
}
case 2:
if(aumentatutti()) {
printf("\n\nPrezzi modificati\n\n");
break;
}
else {
printf("\n\nNessun prodotto trovato\n\n");
break;
}
case 3:
printf("Inserire marca da visualizzare: ");
gets(marcar);
if(visualizzamarca(marcar)==0) {
printf("\nNessun prodotto trovato\n\n");
break;
}
break;
case 4:
printf("\nIl totale da pagare e' : %f",calcolatotale());
break;
case 5:
visualizza_file ();
break;
case 6:
printf("\nInserisci il codice:");
gets(codicer);
fflush(stdin);
float prezzo;
prezzo = prezzocodice(codicer);
if (prezzo == -1){
printf ("\n\nCodice inesistente\n\n");
}
else{
printf ("\n\nIl prezzo e': \t%f\n\n", prezzo);
}
break;
case 7:
break;
default:
printf("Scelta errata");
}
}while(scelta!=7);
}

void aggiungiprodotto()
{
struct sprod prod;
FILE *fp;
if ((fp=fopen("super.dat","a"))==NULL){
printf ("Errore nell'apertura del file");
return;
}
printf("Inserire codice: ");
gets(prod.codice);
printf("Inserire descrizione: ");
gets(prod.descr);
printf("Inserire prezzo: ");
scanf("%f",&prod.prezzo);
fflush(stdin);
printf("Inserire marca: ");
gets(prod.marca);
fwrite(&prod,sizeof(sprod),1,fp);
fclose(fp);
}

void visualizza_file ()
{
sprod prod;
FILE *fp;
if ((fp=fopen("super.dat","r"))==NULL){
printf ("Errore nell'apertura del file");
return;
}
while (!feof (fp)){
fread (&prod, sizeof(prod),1,fp);
if (!feof(fp)){
printf ("\nmarca: %s", prod.marca);
printf ("\ncodice: %s", prod.codice);
printf ("\ndescrizione: %s", prod.descr);
printf ("\nprezzo: %f\n\n", prod.prezzo );
}
}
fclose (fp);
}

int aumentacodice(char *cod)
{
sprod prod;
FILE *fp;
int pos=-1;

if ((fp=fopen("super.dat","r+"))==NULL){
printf ("Errore nell'apertura del file");
return -1;
}

while (!feof (fp)){
fread (&prod, sizeof(prod),1,fp);
if (!feof(fp)){
pos ++;
if (strcmp(prod.codice, cod)==0){
prod.prezzo = prod.prezzo * 1.2;
printf ("prezzo:\t%f", prod.prezzo);
pos = pos * sizeof (prod);
fseek(fp,pos,0);
fwrite(&prod,sizeof(prod),1,fp);
fclose (fp);
return 1;
}
}
}
fclose (fp);
return 0;
}

int aumentatutti(void)
{
sprod prod;
FILE *fp, *fp_supp;

if ((fp=fopen("super.dat","r+"))==NULL){
printf ("\n\nErrore nell'apertura del file\n\n");
return 0;
}

if ((fp_supp=fopen("file_supporto.dat","a"))==NULL){
printf ("\n\nErrore nell'apertura del file di supporto.\n\n");
return 0;
}

while (!feof(fp)){
fread (&prod, sizeof(sprod),1,fp);
if (!feof(fp)){
prod.prezzo = prod.prezzo * 1.2;
fwrite(&prod,sizeof(prod),1,fp_supp);
}
}

fclose (fp);
fclose (fp_supp);

remove("super.dat");
rename("file_supporto.dat", "super.dat");


return 1;
}

int visualizzamarca(char *marca)
{
sprod prod;
FILE *fp;
int n,trovato=0;
if ((fp=fopen("super.dat","r"))==NULL){
printf ("\n\nErrore nell'apertura del file\n\n");
return 0;
}

while (!feof(fp)){
fread (&prod, sizeof(prod),1,fp);
if (!feof(fp)){
if(strcmp(prod.marca,marca)==0){
trovato++;
printf("\n%s %s %f %s\n\n",prod.codice,prod.descr,prod.prezzo,prod.marca);
}
}
}

fclose(fp);
return trovato;
}


float prezzocodice(char *cod)
{
sprod prod;
FILE *fp;

if ((fp=fopen("super.dat","r+"))==NULL){
printf ("\n\nErrore nell'apertura del file\n\n");
return 0;
}

while (!feof(fp)){
fread (&prod, sizeof(prod),1,fp);
if (!feof(fp)){
if(strcmp(prod.codice,cod)==0){
fclose(fp);
return prod.prezzo;
}
}
}

fclose(fp);

return -1;
}


float calcolatotale()
{
FILE *fp;
float totale=0;
char cod[10];
fp=fopen("acquisto.txt","r");
while(fscanf(fp,"%s",cod)!=-1)
totale=totale+prezzocodice(cod);
fclose(fp);
return totale;
}



~§~ Sempre E Solo Lei ~§~

Fenomeno85
05-09-2004, 09:41
allora modificato il programma nell'acquisizione di stringhe. Adesso non c'è più possibilità di creare overflow ;)

Per rendere più semplice, ho creato delle variabili costanti per la lunghezza dei vari campi, così se si vuole per esempio aumentare o diminuire la loro dimensione non c'è più il problema di guardarsi tutte le dimensioni delle variabili.


#include <stdio.h>
#include <conio.h>
#include <string.h>

const lunghezza_codice = 10;
const lunghezza_descr = 100;
const lunghezza_marca = 15;

struct sprod
{
char codice[lunghezza_codice];
char descr[lunghezza_descr];
float prezzo;
char marca[lunghezza_marca];
};

void aggiungiprodotto();
int aumentacodice(char *cod);
int aumentatutti();
float prezzocodice(char *cod);
float calcolatotale();
int visualizzamarca(char *marca);
void visualizza_file ();

void main()
{
int scelta;
char codicer[lunghezza_codice];
char marcar[lunghezza_marca];
do
{
printf("0-Aggiungere nuovo prodotto\n");
printf("1-dato un codice articolo, aumentare il suo prezzo del 20%\n");
printf("2-Aumentare i prezzi di tutti gli articoli del 20%\n");
printf("3-Stampare tutti gli articoli della stessa marca data in input\n");
printf("4-stampare il totale da pagare\n");
printf("5-se vuoi stampare a video tutto il file\n");
printf("6-stampare il prezzo dato un codice\n");
printf("7-Uscita\n");
printf("Scegli: ");
scanf("%d",&scelta);
fflush(stdin);
switch(scelta)
{
case 0:
aggiungiprodotto();
break;
case 1:
printf("Inserire codice da modificare: ");
fgets (codicer,lunghezza_codice,stdin);
fflush(stdin);
if(aumentacodice(codicer)) {
printf("\nPrezzo modificato");
break;
}
else {
printf("\nCodice non trovato\n\n");
break;
}
case 2:
if(aumentatutti()) {
printf("\n\nPrezzi modificati\n\n");
break;
}
else {
printf("\n\nNessun prodotto trovato\n\n");
break;
}
case 3:
printf("Inserire marca da visualizzare: ");
fgets (marcar,lunghezza_marca,stdin);
if(visualizzamarca(marcar)==0) {
printf("\nNessun prodotto trovato\n\n");
break;
}
break;
case 4:
printf("\nIl totale da pagare e' : %f",calcolatotale());
break;
case 5:
visualizza_file ();
break;
case 6:
printf("\nInserisci il codice:");
fgets (codicer, lunghezza_codice, stdin);
fflush(stdin);
float prezzo;
prezzo = prezzocodice(codicer);
if (prezzo == -1){
printf ("\n\nCodice inesistente\n\n");
}
else{
printf ("\n\nIl prezzo e': \t%f\n\n", prezzo);
}
break;
case 7:
break;
default:
printf("Scelta errata");
}
}while(scelta!=7);
}

void aggiungiprodotto()
{
struct sprod prod;
FILE *fp;
if ((fp=fopen("super.dat","a"))==NULL){
printf ("Errore nell'apertura del file");
return;
}
fflush(stdin);
printf("Inserire codice: ");
fgets (prod.codice, lunghezza_codice, stdin);
fflush(stdin);
printf("Inserire descrizione: ");
fgets(prod.descr, lunghezza_descr, stdin);
fflush(stdin);
printf("Inserire prezzo: ");
scanf("%f",&prod.prezzo);
fflush(stdin);
printf("Inserire marca: ");
fgets(prod.marca, lunghezza_marca, stdin);
fflush(stdin);
fwrite(&prod,sizeof(sprod),1,fp);
fclose(fp);
}

void visualizza_file ()
{
sprod prod;
FILE *fp;
if ((fp=fopen("super.dat","r"))==NULL){
printf ("Errore nell'apertura del file");
return;
}
while (!feof (fp)){
fread (&prod, sizeof(prod),1,fp);
if (!feof(fp)){
printf ("\nmarca: %s", prod.marca);
printf ("\ncodice: %s", prod.codice);
printf ("\ndescrizione: %s", prod.descr);
printf ("\nprezzo: %f\n\n", prod.prezzo );
}
}
fclose (fp);
}

int aumentacodice(char *cod)
{
sprod prod;
FILE *fp;
int pos=-1;

if ((fp=fopen("super.dat","r+"))==NULL){
printf ("Errore nell'apertura del file");
return -1;
}

while (!feof (fp)){
fread (&prod, sizeof(prod),1,fp);
if (!feof(fp)){
pos ++;
if (strcmp(prod.codice, cod)==0){
prod.prezzo = prod.prezzo * 1.2;
printf ("prezzo:\t%f", prod.prezzo);
pos = pos * sizeof (prod);
fseek(fp,pos,0);
fwrite(&prod,sizeof(prod),1,fp);
fclose (fp);
return 1;
}
}
}
fclose (fp);
return 0;
}

int aumentatutti(void)
{
sprod prod;
FILE *fp, *fp_supp;

if ((fp=fopen("super.dat","r+"))==NULL){
printf ("\n\nErrore nell'apertura del file\n\n");
return 0;
}

if ((fp_supp=fopen("file_supporto.dat","a"))==NULL){
printf ("\n\nErrore nell'apertura del file di supporto.\n\n");
return 0;
}

while (!feof(fp)){
fread (&prod, sizeof(sprod),1,fp);
if (!feof(fp)){
prod.prezzo = prod.prezzo * 1.2;
fwrite(&prod,sizeof(prod),1,fp_supp);
}
}

fclose (fp);
fclose (fp_supp);

remove("super.dat");
rename("file_supporto.dat", "super.dat");


return 1;
}

int visualizzamarca(char *marca)
{
sprod prod;
FILE *fp;
int n,trovato=0;
if ((fp=fopen("super.dat","r"))==NULL){
printf ("\n\nErrore nell'apertura del file\n\n");
return 0;
}

while (!feof(fp)){
fread (&prod, sizeof(prod),1,fp);
if (!feof(fp)){
if(strcmp(prod.marca,marca)==0){
trovato++;
printf("\n%s %s %f %s\n\n",prod.codice,prod.descr,prod.prezzo,prod.marca);
}
}
}

fclose(fp);
return trovato;
}


float prezzocodice(char *cod)
{
sprod prod;
FILE *fp;

if ((fp=fopen("super.dat","r+"))==NULL){
printf ("\n\nErrore nell'apertura del file\n\n");
return 0;
}

while (!feof(fp)){
fread (&prod, sizeof(prod),1,fp);
if (!feof(fp)){
if(strcmp(prod.codice,cod)==0){
fclose(fp);
return prod.prezzo;
}
}
}

fclose(fp);

return -1;
}


float calcolatotale()
{
FILE *fp;
float totale=0;
char cod[10];
fp=fopen("acquisto.txt","r");
while(fscanf(fp,"%s",cod)!=-1)
totale=totale+prezzocodice(cod);
fclose(fp);
return totale;
}



~§~ Sempre E Solo Lei ~§~

Fenomeno85
05-09-2004, 17:53
marfer hai capito le modiche che ho fatto?!

ps: qualcuno mi spiega o ha qualche link per i file di testo?!

~§~ Sempre E Solo Lei ~§~

marfer3
05-09-2004, 18:38
domani le guardo con calma e ti faccio sapere. Grazie.

Fenomeno85
05-09-2004, 18:51
Originariamente inviato da marfer3
domani le guardo con calma e ti faccio sapere. Grazie.

ok ;)

~§~ Sempre E Solo Lei ~§~

Zorgolo
06-09-2004, 13:58
uhz..
per prima cosa ti consiglio di usare anche la letterina magica "b" quando apri un file ... quindi fopen(...., "rb+") o "wb" o "rb" .. in base alle esigenze... questo specifica che il file dovrà essere aperto in modo binario.
Altra cosa : fread (&prod, sizeof(prod),1,fp);
usa fread(&prod,1,sizeof(prod),fp);
la differenza è che fread restituisce il "numero di elementi letti" ..
ovvero nel primo caso se per esempio la tua struttura fosse di 100 byte e fread riesce a leggerne solo 99 il risultato è 0 in quanto non è riuscito a leggere nessuna struttura completa.
Nel secondo caso il risultato sarà 99.
Sebbene "concettualmente" la tua scrittura è piu' corretta, trovo che sia più semplice fare un debug utilizzando invece la seconda "scrittura" :)