Accueil > > > TABLES DE TRI ASSOCIES AUX FICHIERS
TABLES DE TRI ASSOCIES AUX FICHIERS
Information sur la source
Description
Voila 3 problemes resolus dans cette source:
- Exploitation non sequentielle des fichiers, avec des tables associes
- Tri des ces tables (indirectement, des fichiers)
- Construction des listes de sortie dynamiques (avec les dimmension des colonnes variables, selon le contexte des donnees)
Utiliser le compilateur GCC sous WINDOWS.
Source
- //08-sep-2008 16:57:32
-
- /* La ligne de commande pour construire listocc.exe
- gcc -fpack-struct -Wno-pointer-sign -olstoc.exe lstoc.c
- */
-
- typedef unsigned short ushort;
- typedef unsigned long ulong;
- typedef unsigned char uchar;
-
- #include <stdio.h>
- #include <conio.h>
- #include <io.h>
- #include <stdlib.h>
- #include <string.h>
- #include <math.h>
- #include <fcntl.h>
- #include <sys\stat.h>
-
- //-------------------------------------
- uchar nom_nomenclature[]="NOMENCL.FFF";
- short nf_nom;
- ulong nb_art_nom;
- ushort RCS_NOM; //longueur d'article
- struct ART_NOM ///structure d'article
- {
- ulong code;
- uchar nom_d_article[40];
- uchar um[3];
- uchar rien[29];
- } art_nom;
- struct TAB_NOM //table associe au fichier
- {
- ulong code;
- uchar nom_d_article[40];
- ulong position_dans_fichier_nom;
- } *p_nom,*q_nom;
- int fc_nom(void const *a,void const *b) //fonction pour qsort
- {
- struct TAB_NOM const *p1=a;
- struct TAB_NOM const *p2=b;
- return strnicmp(p1->nom_d_article,p2->nom_d_article,40);
- }
- ulong LIEU;
- int cherche_nom(ulong code) //function qui cherche un certain code
- {
- for(LIEU=0;LIEU<nb_art_nom;LIEU++)
- {
- p_nom=q_nom+LIEU;
- if(code==p_nom->code) return 0;
- }
- return 1;
- }
- //--------------------------------
- uchar nom_du_stock[]="STOCKS.FFF";
- short nf_stock;
- ulong nb_art_stock;
- ushort RCS_STOCK; //longueur d'article
- struct ART_STOCK //structure d'article
- {
- ushort gestion;
- ulong code;
- double prix; // *1000 pour obtenir des valeurs entiers
- double quantite; // *1000 idem
- uchar rien[6];
- } art_stock;
- struct TAB_STOCK //table associe au fichier
- {
- ulong position_dans_table_nom;
- double prix;
- ushort position_dans_fichier_stock;
- } *p_stock,*q_stock;
- int fc_stock(void const *a,void const *b) //fonction pour qsort
- {
- struct TAB_STOCK const *p1=a;
- struct TAB_STOCK const *p2=b;
- if(p1->position_dans_table_nom<p2->position_dans_table_nom) return -1;
- if(p1->position_dans_table_nom>p2->position_dans_table_nom) return 1;
- if(p1->prix<p2->prix) return -1;
- if(p1->prix>p2->prix) return 1;
- return 0;
- }
-
- void tete_de_liste(void);
- void total_code(void);
-
- //Variables
- //---------
- FILE *fich;
- ushort nb_lignes_sur_page,compteur_lignes;
- uchar man[500]; //string pour sprintf
-
- ulong i,entier;
- ushort j;
-
- ulong ancien_code;
-
- ulong LIBRE;
- uchar *O;
-
- ushort mois,annee;
-
- double quantite_code,valeur_code,valeur_courante,VALEUR_TOTALE;
-
- uchar nb_positions_sur_code,nb_char[6];
- ushort ligne_max;
-
- int main(void)
- {
- RCS_NOM=sizeof(art_nom);
- RCS_STOCK=sizeof(art_stock);
-
- //Pour la date des stocks
- mois=4;
- annee=2008;
-
- //Ouverture du fichier nomenclature
- if((nf_nom=open(nom_nomenclature,O_BINARY|O_RDONLY))<1)
- {
- printf("\nFichier %s non trouve.",nom_nomenclature);
- exit(0);
- }
-
- //Longueur en octets
- nb_art_nom=filelength(nf_nom);
-
- //Le fichier est valide ?
- if(nb_art_nom%RCS_NOM)
- {
- printf("\nFichier %s corrompu.",nom_nomenclature);
- exit(0);
- }
-
- //Longueur en articles
- nb_art_nom/=RCS_NOM;
-
- //Ouverture du fichier stocks
- if((nf_stock=open(nom_du_stock,O_BINARY|O_RDONLY))<1)
- {
- printf("\nFichier %s non trouve.",nom_du_stock);
- exit(0);
- }
-
- //Longueur en octets
- nb_art_stock=filelength(nf_stock);
-
- //Le fichier est valide ?
- if(nb_art_stock%RCS_STOCK)
- {
- printf("\nFichier %s corrompu.",nom_du_stock);
- exit(0);
- }
-
- //Longueur en articles
- nb_art_stock/=RCS_STOCK;
-
- //Necessaire de memoire pour stocker les tables
- LIBRE=nb_art_nom*sizeof(*q_nom)+nb_art_stock*sizeof(*q_stock);
-
- //Reservation de memoire
- if((O=malloc((size_t)LIBRE))==NULL)
- {
- printf("\nImpossible de reserver %lu d'octets en memoire.",LIBRE);
- exit(0);
- }
-
- //Construction de la table TAB_NOM
- p_nom=q_nom=(struct TAB_NOM *)O;
- entier=0; //nombre d-elements
- for(i=0;i<nb_art_nom;i++)
- {
- read(nf_nom,&art_nom,RCS_NOM);
- if(!art_nom.code) continue; //article efface
- p_nom->code=art_nom.code;
- strncpy(p_nom->nom_d_article,art_nom.nom_d_article,40);
- p_nom->position_dans_fichier_nom=i;
- p_nom++;entier++;
- }
- nb_art_nom=entier;
- //Tri de la table TAB_NOM
- qsort((uchar *)q_nom,nb_art_nom,sizeof(*q_nom),fc_nom);
-
- //La fin de la table TAB_NOM
- p_nom=q_nom+nb_art_nom;
-
- //Construction de la table TAB_STOCK
- p_stock=q_stock=(struct TAB_STOCK *)p_nom;
- entier=0;
- //et calcul des nombres des characters des colonnes de l'entet de la liste
- memset(nb_char,0,6);
- for(i=0;i<nb_art_stock;i++)
- {
- read(nf_stock,&art_stock,RCS_STOCK);
- //Pour cet exemple, seulement les gestions 11 et 13
- if(art_stock.gestion!=11&&art_stock.gestion!=13) continue;
- if(cherche_nom(art_stock.code)) continue;
-
- lseek(nf_nom,p_nom->position_dans_fichier_nom*RCS_NOM,SEEK_SET);
- read(nf_nom,&art_nom,RCS_NOM);
-
- //combien des chars
- for(j=40;j;j--) if(art_nom.nom_d_article[j-1]!=' ') break;
- if(j>nb_char[5]) nb_char[5]=j;
-
- p_stock->position_dans_table_nom=LIEU; //pour ordre alphabetique
- p_stock->prix=art_stock.prix;
- p_stock->position_dans_fichier_stock=i;
- p_stock++;entier++;
-
- //combien des chars pour code
- j=sprintf(man,"%lu",art_stock.code);
- if(nb_char[0]<j) nb_char[0]=j;
-
- //combien des chars pour prix
- j=sprintf(man,"%.3f",1e-3*art_stock.prix);
- if(j>nb_char[1]) nb_char[1]=j;
-
- //combien des chars pour quantite
- j=sprintf(man,"%.3f",1e-3*art_stock.quantite);
- if(j>nb_char[3]) nb_char[3]=j;
-
- //calcul de la valeur
- valeur_courante=floor(1e-4*fabs(art_stock.quantite)*art_stock.prix+0.5);
- if(art_stock.quantite<0e0) valeur_courante=-valeur_courante;
-
- //combien des chars pour valeur
- j=sprintf(man,"%.2f",1e-2*valeur_courante);
- if(j>nb_char[4]) nb_char[4]=j;
- }
- nb_art_stock=entier;
- //Tri de la table TAB_STOCK
- qsort((uchar *)q_stock,nb_art_stock,sizeof(*q_stock),fc_stock);
-
- //pour la ligne de total_code, calcul des colonnes
- nb_positions_sur_code=0;
- ancien_code=0xFFFFFFFF;
- for(i=0;i<nb_art_stock;i++)
- {
- p_stock=q_stock+i;
- lseek(nf_stock,p_stock->position_dans_fichier_stock*RCS_STOCK,SEEK_SET);
- read(nf_stock,&art_stock,RCS_STOCK);
- if(ancien_code!=art_stock.code)
- {
- if(ancien_code!=0xFFFFFFFF)
- {
- j=sprintf(man,"%.3f",1e-3*quantite_code);
- if(j>nb_char[3]) nb_char[3]=j;
- j=sprintf(man,"%.2f",1e-2*valeur_code);
- if(j>nb_char[4]) nb_char[4]=j;
- }
- ancien_code=art_stock.code;
- valeur_code=quantite_code=0e0;
- }
- valeur_courante=floor(1e-4*fabs(art_stock.quantite)*art_stock.prix+0.5);
- if(art_stock.quantite<0e0) valeur_courante=-valeur_courante;
- quantite_code+=art_stock.quantite;
- valeur_code+=valeur_courante;
- }
- if(ancien_code!=0xFFFFFFFF)
- {
- j=sprintf(man,"%.3f",1e-3*quantite_code);
- if(j>nb_char[3]) nb_char[3]=j;
- j=sprintf(man,"%.2f",1e-2*valeur_code);
- if(j>nb_char[4]) nb_char[4]=j;
- }
-
- //Les longueurs minimum necessaires
- if(nb_char[0]<4) nb_char[0]=4; //longueur du mot "Code" = 4
- if(nb_char[1]<4) nb_char[1]=4; //longueur du mot "Prix" = 4
- nb_char[2]=3; //longueur du mot "U/M" = 3
- if(nb_char[3]<8) nb_char[3]=8; //longueur du mot "Quantite" = 8
- if(nb_char[4]<6) nb_char[4]=6; //longueur du mot "Valeur" = 6
- if(nb_char[5]<7) nb_char[5]=7; //longueur du mot "Denomme" = 7
-
- //Calcule de la longueur d'une ligne
- ligne_max=1;for(j=0;j<6;j++) ligne_max+=nb_char[j]+1;
-
- printf("Nombre des lignes sur une page:");
- scanf("%u",&nb_lignes_sur_page);
- compteur_lignes=nb_lignes_sur_page+1;
-
- //Fichier image de la liste sortie
- fich=stdout;
- // ou
- //fich=stdprn;
- // ou
- //fich=fopen("liste.doc","wt");
-
- //Debut de la liste
- VALEUR_TOTALE=0e0;
- nb_positions_sur_code=0;
- ancien_code=0xFFFFFFFF;
- for(i=0;i<nb_art_stock;i++)
- {
- p_stock=q_stock+i;
- lseek(nf_stock,p_stock->position_dans_fichier_stock*RCS_STOCK,SEEK_SET);
- read(nf_stock,&art_stock,RCS_STOCK);
-
- //Si un autre code
- if(ancien_code!=art_stock.code) total_code();
-
- //Si on depasse la capacite de la page
- if(compteur_lignes+1>nb_lignes_sur_page)
- {
- printf("Presse Enter pour continuer ou X pour abandonner");
- if(toupper(getch())=='X') return 1;
- tete_de_liste();
- }
-
- compteur_lignes++;
-
- if(nb_positions_sur_code==0) //Premiere position sur cet code
- {
- cherche_nom(art_stock.code);
- lseek(nf_nom,p_nom->position_dans_fichier_nom*RCS_NOM,SEEK_SET);
- read(nf_nom,&art_nom,RCS_NOM);
- if(art_nom.nom_d_article[0]==' ') art_nom.nom_d_article[0]='?';
- }
- else //Un autre position
- {
- memset(art_nom.um,' ',3);
- memset(art_nom.nom_d_article,' ',40);
- }
- valeur_courante=floor(1e-4*fabs(art_stock.quantite)*art_stock.prix+0.5);
- if(art_stock.quantite<0e0) valeur_courante=-valeur_courante;
-
- VALEUR_TOTALE+=valeur_courante;
-
- if(art_nom.nom_d_article[0]!=' ') //Premiere position sur cet code
- {
- fprintf(fich,"|%*lu|",nb_char[0],art_stock.code);
- }
- else
- {
- fprintf(fich,"|%*s|",nb_char[0],"");
- }
- fprintf(fich,"%*.3f|",nb_char[1],1e-3*art_stock.prix);
- fprintf(fich,"%3.3s|",art_nom.um);
- fprintf(fich,"%*.3f|",nb_char[3],1e-3*art_stock.quantite);
- fprintf(fich,"%*.2f|",nb_char[4],1e-2*valeur_courante);
- fprintf(fich,"%*.*s|\n",nb_char[5],nb_char[5],art_nom.nom_d_article);
-
- quantite_code+=art_stock.quantite;
- valeur_code+=valeur_courante;
- nb_positions_sur_code++;
- }
- total_code();
-
- j=nb_char[3]+nb_char[4]+1;
- fprintf(fich,"|%*sTotal general|%*.2f|%*s|\n",nb_char[0]+nb_char[1]+nb_char[2]+2-13,"",j,1e-2*VALEUR_TOTALE,nb_char[5],"");
-
- memset(man,'=',ligne_max);man[ligne_max]='\0';
- fprintf(fich,"%s\n",man);
-
- close(nf_nom);
- close(nf_stock);
-
- free((uchar *)O);
-
- return 1;
- }
-
- void tete_de_liste(void)
- {
- //title au centre
- j=sprintf(man,"La liste des stocks le 01/%02u/%04u",mois,annee);
- if(j>ligne_max) j=ligne_max;j=ligne_max-j;j>>=1;
- fprintf(fich,"\n%*s%s\n",j,"",man);
-
- memset(man,'=',ligne_max);man[ligne_max]='\0';
- fprintf(fich,"%s\n",man);
-
- fprintf(fich,"|%*sCode|%*sPrix|U/M|%*sQuantite|%*sValeur|Denomme%*s|\n",
- nb_char[0]-4,"",nb_char[1]-4,"",nb_char[3]-8,"",nb_char[4]-6,"",nb_char[5]-7,"");
-
- fprintf(fich,"%s\n",man);
-
- compteur_lignes=4;
- }
-
- void total_code(void)
- {
- if(ancien_code!=0xFFFFFFFF&&nb_positions_sur_code>1)
- {
- if(compteur_lignes+1>nb_lignes_sur_page)
- {
- printf("Presse Enter pour continuer ou X pour abandonner");
- if(toupper(getch())=='X') exit(0);
- tete_de_liste();
- }
-
- compteur_lignes++;
-
- memset(man,'-',50);
- fprintf(fich,"|%*s|%*.*s|%*.*s|",nb_char[0],"",nb_char[1],nb_char[1],man,nb_char[2],nb_char[2],man);
- fprintf(fich,"%*.3f|",nb_char[3],1e-3*quantite_code);
- fprintf(fich,"%*.2f|",nb_char[4],1e-2*valeur_code);
- fprintf(fich,"%*.*s|\n",nb_char[5],nb_char[5],man);
- }
- ancien_code=art_stock.code;
- valeur_code=quantite_code=0e0;
- nb_positions_sur_code=0;
- }
//08-sep-2008 16:57:32
/* La ligne de commande pour construire listocc.exe
gcc -fpack-struct -Wno-pointer-sign -olstoc.exe lstoc.c
*/
typedef unsigned short ushort;
typedef unsigned long ulong;
typedef unsigned char uchar;
#include <stdio.h>
#include <conio.h>
#include <io.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
#include <fcntl.h>
#include <sys\stat.h>
//-------------------------------------
uchar nom_nomenclature[]="NOMENCL.FFF";
short nf_nom;
ulong nb_art_nom;
ushort RCS_NOM; //longueur d'article
struct ART_NOM ///structure d'article
{
ulong code;
uchar nom_d_article[40];
uchar um[3];
uchar rien[29];
} art_nom;
struct TAB_NOM //table associe au fichier
{
ulong code;
uchar nom_d_article[40];
ulong position_dans_fichier_nom;
} *p_nom,*q_nom;
int fc_nom(void const *a,void const *b) //fonction pour qsort
{
struct TAB_NOM const *p1=a;
struct TAB_NOM const *p2=b;
return strnicmp(p1->nom_d_article,p2->nom_d_article,40);
}
ulong LIEU;
int cherche_nom(ulong code) //function qui cherche un certain code
{
for(LIEU=0;LIEU<nb_art_nom;LIEU++)
{
p_nom=q_nom+LIEU;
if(code==p_nom->code) return 0;
}
return 1;
}
//--------------------------------
uchar nom_du_stock[]="STOCKS.FFF";
short nf_stock;
ulong nb_art_stock;
ushort RCS_STOCK; //longueur d'article
struct ART_STOCK //structure d'article
{
ushort gestion;
ulong code;
double prix; // *1000 pour obtenir des valeurs entiers
double quantite; // *1000 idem
uchar rien[6];
} art_stock;
struct TAB_STOCK //table associe au fichier
{
ulong position_dans_table_nom;
double prix;
ushort position_dans_fichier_stock;
} *p_stock,*q_stock;
int fc_stock(void const *a,void const *b) //fonction pour qsort
{
struct TAB_STOCK const *p1=a;
struct TAB_STOCK const *p2=b;
if(p1->position_dans_table_nom<p2->position_dans_table_nom) return -1;
if(p1->position_dans_table_nom>p2->position_dans_table_nom) return 1;
if(p1->prix<p2->prix) return -1;
if(p1->prix>p2->prix) return 1;
return 0;
}
void tete_de_liste(void);
void total_code(void);
//Variables
//---------
FILE *fich;
ushort nb_lignes_sur_page,compteur_lignes;
uchar man[500]; //string pour sprintf
ulong i,entier;
ushort j;
ulong ancien_code;
ulong LIBRE;
uchar *O;
ushort mois,annee;
double quantite_code,valeur_code,valeur_courante,VALEUR_TOTALE;
uchar nb_positions_sur_code,nb_char[6];
ushort ligne_max;
int main(void)
{
RCS_NOM=sizeof(art_nom);
RCS_STOCK=sizeof(art_stock);
//Pour la date des stocks
mois=4;
annee=2008;
//Ouverture du fichier nomenclature
if((nf_nom=open(nom_nomenclature,O_BINARY|O_RDONLY))<1)
{
printf("\nFichier %s non trouve.",nom_nomenclature);
exit(0);
}
//Longueur en octets
nb_art_nom=filelength(nf_nom);
//Le fichier est valide ?
if(nb_art_nom%RCS_NOM)
{
printf("\nFichier %s corrompu.",nom_nomenclature);
exit(0);
}
//Longueur en articles
nb_art_nom/=RCS_NOM;
//Ouverture du fichier stocks
if((nf_stock=open(nom_du_stock,O_BINARY|O_RDONLY))<1)
{
printf("\nFichier %s non trouve.",nom_du_stock);
exit(0);
}
//Longueur en octets
nb_art_stock=filelength(nf_stock);
//Le fichier est valide ?
if(nb_art_stock%RCS_STOCK)
{
printf("\nFichier %s corrompu.",nom_du_stock);
exit(0);
}
//Longueur en articles
nb_art_stock/=RCS_STOCK;
//Necessaire de memoire pour stocker les tables
LIBRE=nb_art_nom*sizeof(*q_nom)+nb_art_stock*sizeof(*q_stock);
//Reservation de memoire
if((O=malloc((size_t)LIBRE))==NULL)
{
printf("\nImpossible de reserver %lu d'octets en memoire.",LIBRE);
exit(0);
}
//Construction de la table TAB_NOM
p_nom=q_nom=(struct TAB_NOM *)O;
entier=0; //nombre d-elements
for(i=0;i<nb_art_nom;i++)
{
read(nf_nom,&art_nom,RCS_NOM);
if(!art_nom.code) continue; //article efface
p_nom->code=art_nom.code;
strncpy(p_nom->nom_d_article,art_nom.nom_d_article,40);
p_nom->position_dans_fichier_nom=i;
p_nom++;entier++;
}
nb_art_nom=entier;
//Tri de la table TAB_NOM
qsort((uchar *)q_nom,nb_art_nom,sizeof(*q_nom),fc_nom);
//La fin de la table TAB_NOM
p_nom=q_nom+nb_art_nom;
//Construction de la table TAB_STOCK
p_stock=q_stock=(struct TAB_STOCK *)p_nom;
entier=0;
//et calcul des nombres des characters des colonnes de l'entet de la liste
memset(nb_char,0,6);
for(i=0;i<nb_art_stock;i++)
{
read(nf_stock,&art_stock,RCS_STOCK);
//Pour cet exemple, seulement les gestions 11 et 13
if(art_stock.gestion!=11&&art_stock.gestion!=13) continue;
if(cherche_nom(art_stock.code)) continue;
lseek(nf_nom,p_nom->position_dans_fichier_nom*RCS_NOM,SEEK_SET);
read(nf_nom,&art_nom,RCS_NOM);
//combien des chars
for(j=40;j;j--) if(art_nom.nom_d_article[j-1]!=' ') break;
if(j>nb_char[5]) nb_char[5]=j;
p_stock->position_dans_table_nom=LIEU; //pour ordre alphabetique
p_stock->prix=art_stock.prix;
p_stock->position_dans_fichier_stock=i;
p_stock++;entier++;
//combien des chars pour code
j=sprintf(man,"%lu",art_stock.code);
if(nb_char[0]<j) nb_char[0]=j;
//combien des chars pour prix
j=sprintf(man,"%.3f",1e-3*art_stock.prix);
if(j>nb_char[1]) nb_char[1]=j;
//combien des chars pour quantite
j=sprintf(man,"%.3f",1e-3*art_stock.quantite);
if(j>nb_char[3]) nb_char[3]=j;
//calcul de la valeur
valeur_courante=floor(1e-4*fabs(art_stock.quantite)*art_stock.prix+0.5);
if(art_stock.quantite<0e0) valeur_courante=-valeur_courante;
//combien des chars pour valeur
j=sprintf(man,"%.2f",1e-2*valeur_courante);
if(j>nb_char[4]) nb_char[4]=j;
}
nb_art_stock=entier;
//Tri de la table TAB_STOCK
qsort((uchar *)q_stock,nb_art_stock,sizeof(*q_stock),fc_stock);
//pour la ligne de total_code, calcul des colonnes
nb_positions_sur_code=0;
ancien_code=0xFFFFFFFF;
for(i=0;i<nb_art_stock;i++)
{
p_stock=q_stock+i;
lseek(nf_stock,p_stock->position_dans_fichier_stock*RCS_STOCK,SEEK_SET);
read(nf_stock,&art_stock,RCS_STOCK);
if(ancien_code!=art_stock.code)
{
if(ancien_code!=0xFFFFFFFF)
{
j=sprintf(man,"%.3f",1e-3*quantite_code);
if(j>nb_char[3]) nb_char[3]=j;
j=sprintf(man,"%.2f",1e-2*valeur_code);
if(j>nb_char[4]) nb_char[4]=j;
}
ancien_code=art_stock.code;
valeur_code=quantite_code=0e0;
}
valeur_courante=floor(1e-4*fabs(art_stock.quantite)*art_stock.prix+0.5);
if(art_stock.quantite<0e0) valeur_courante=-valeur_courante;
quantite_code+=art_stock.quantite;
valeur_code+=valeur_courante;
}
if(ancien_code!=0xFFFFFFFF)
{
j=sprintf(man,"%.3f",1e-3*quantite_code);
if(j>nb_char[3]) nb_char[3]=j;
j=sprintf(man,"%.2f",1e-2*valeur_code);
if(j>nb_char[4]) nb_char[4]=j;
}
//Les longueurs minimum necessaires
if(nb_char[0]<4) nb_char[0]=4; //longueur du mot "Code" = 4
if(nb_char[1]<4) nb_char[1]=4; //longueur du mot "Prix" = 4
nb_char[2]=3; //longueur du mot "U/M" = 3
if(nb_char[3]<8) nb_char[3]=8; //longueur du mot "Quantite" = 8
if(nb_char[4]<6) nb_char[4]=6; //longueur du mot "Valeur" = 6
if(nb_char[5]<7) nb_char[5]=7; //longueur du mot "Denomme" = 7
//Calcule de la longueur d'une ligne
ligne_max=1;for(j=0;j<6;j++) ligne_max+=nb_char[j]+1;
printf("Nombre des lignes sur une page:");
scanf("%u",&nb_lignes_sur_page);
compteur_lignes=nb_lignes_sur_page+1;
//Fichier image de la liste sortie
fich=stdout;
// ou
//fich=stdprn;
// ou
//fich=fopen("liste.doc","wt");
//Debut de la liste
VALEUR_TOTALE=0e0;
nb_positions_sur_code=0;
ancien_code=0xFFFFFFFF;
for(i=0;i<nb_art_stock;i++)
{
p_stock=q_stock+i;
lseek(nf_stock,p_stock->position_dans_fichier_stock*RCS_STOCK,SEEK_SET);
read(nf_stock,&art_stock,RCS_STOCK);
//Si un autre code
if(ancien_code!=art_stock.code) total_code();
//Si on depasse la capacite de la page
if(compteur_lignes+1>nb_lignes_sur_page)
{
printf("Presse Enter pour continuer ou X pour abandonner");
if(toupper(getch())=='X') return 1;
tete_de_liste();
}
compteur_lignes++;
if(nb_positions_sur_code==0) //Premiere position sur cet code
{
cherche_nom(art_stock.code);
lseek(nf_nom,p_nom->position_dans_fichier_nom*RCS_NOM,SEEK_SET);
read(nf_nom,&art_nom,RCS_NOM);
if(art_nom.nom_d_article[0]==' ') art_nom.nom_d_article[0]='?';
}
else //Un autre position
{
memset(art_nom.um,' ',3);
memset(art_nom.nom_d_article,' ',40);
}
valeur_courante=floor(1e-4*fabs(art_stock.quantite)*art_stock.prix+0.5);
if(art_stock.quantite<0e0) valeur_courante=-valeur_courante;
VALEUR_TOTALE+=valeur_courante;
if(art_nom.nom_d_article[0]!=' ') //Premiere position sur cet code
{
fprintf(fich,"|%*lu|",nb_char[0],art_stock.code);
}
else
{
fprintf(fich,"|%*s|",nb_char[0],"");
}
fprintf(fich,"%*.3f|",nb_char[1],1e-3*art_stock.prix);
fprintf(fich,"%3.3s|",art_nom.um);
fprintf(fich,"%*.3f|",nb_char[3],1e-3*art_stock.quantite);
fprintf(fich,"%*.2f|",nb_char[4],1e-2*valeur_courante);
fprintf(fich,"%*.*s|\n",nb_char[5],nb_char[5],art_nom.nom_d_article);
quantite_code+=art_stock.quantite;
valeur_code+=valeur_courante;
nb_positions_sur_code++;
}
total_code();
j=nb_char[3]+nb_char[4]+1;
fprintf(fich,"|%*sTotal general|%*.2f|%*s|\n",nb_char[0]+nb_char[1]+nb_char[2]+2-13,"",j,1e-2*VALEUR_TOTALE,nb_char[5],"");
memset(man,'=',ligne_max);man[ligne_max]='\0';
fprintf(fich,"%s\n",man);
close(nf_nom);
close(nf_stock);
free((uchar *)O);
return 1;
}
void tete_de_liste(void)
{
//title au centre
j=sprintf(man,"La liste des stocks le 01/%02u/%04u",mois,annee);
if(j>ligne_max) j=ligne_max;j=ligne_max-j;j>>=1;
fprintf(fich,"\n%*s%s\n",j,"",man);
memset(man,'=',ligne_max);man[ligne_max]='\0';
fprintf(fich,"%s\n",man);
fprintf(fich,"|%*sCode|%*sPrix|U/M|%*sQuantite|%*sValeur|Denomme%*s|\n",
nb_char[0]-4,"",nb_char[1]-4,"",nb_char[3]-8,"",nb_char[4]-6,"",nb_char[5]-7,"");
fprintf(fich,"%s\n",man);
compteur_lignes=4;
}
void total_code(void)
{
if(ancien_code!=0xFFFFFFFF&&nb_positions_sur_code>1)
{
if(compteur_lignes+1>nb_lignes_sur_page)
{
printf("Presse Enter pour continuer ou X pour abandonner");
if(toupper(getch())=='X') exit(0);
tete_de_liste();
}
compteur_lignes++;
memset(man,'-',50);
fprintf(fich,"|%*s|%*.*s|%*.*s|",nb_char[0],"",nb_char[1],nb_char[1],man,nb_char[2],nb_char[2],man);
fprintf(fich,"%*.3f|",nb_char[3],1e-3*quantite_code);
fprintf(fich,"%*.2f|",nb_char[4],1e-2*valeur_code);
fprintf(fich,"%*.*s|\n",nb_char[5],nb_char[5],man);
}
ancien_code=art_stock.code;
valeur_code=quantite_code=0e0;
nb_positions_sur_code=0;
}
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
Copie de fichiers de nom long avec Visual C++ sous Windows98 [ par ABT ]
Salut, Je développe une application avec Visual C++, l'une de ses est de copier des fichiers à partir d'un répertoire vers un autre. J'utilise pour ce
Liens entre 2 tables sous Base Oracle [ par Charly06 ]
Bonjour ma question est la suivante : Comment créer un lien entre 2 tables, sachant que je suis sous Oracle. D'avance merci
Question simple [ par SysBreak ]
Salut, j'ai Borland C++ 5 v.pro et j'aimerais savoir dans quel répertoire je dois enregistrer mes fichiers sources créés ? Pour les projets j'ai bien
Comment afficher la liste des fichiers dans le composant List View [ par kanimana ]
Bonjour Svp, indiquez moi la fonction qui permettera d'afficher les fichier contenu dans un répertoire dans le composant ListView, avec les détails
pb de base de donnee en C [ par tequ13 ]
j'aimerais savoir comment faire pour charger des fichiers (*.txt) a l'ouverture d'un programme pour ensuite les comparer et repérer les doublons pour
c koi les fichiers h? [ par etmerde ]
je suis débutant(mais alors là, plus nul que ça tu trouves pas), et j'ai vu dans les codes c++ des trucs du genre include (machinchose.h) ou un truc d
problèmes liens entre fichiers C et C++ dans un projet Visual C++ 6.0 [ par nico ]
J'ai récupéré un projet contenant des fichiers écrits en C. Le fichier "principal" de ce projet également écrit en C fait appel à des fonctions se tro
Les fichiers téléchargeables [ par Fantoooom ]
Salut,J'ai téléchargé plusieurs codes sources avec leur fichiers, mais il manque toujours un fichier .h dans les fichiers recu au téléchargement et il
Les fichiers .h ou .hpp [ par Fantoooom ]
Salut,Je ne sais pas comment savoir quelle fonction se trouve dans quelle fichier ???Quelqu'un pourrait me dire où il est possible que je trouve un ge
Problème pour lire les fichiers audio dans un programme C++ [ par Nicolas ]
Pour un projet C++ (linéaire),il souhaiterais réalisé une bibliothèque musical(.mp3, .wav). J'aurais besoin pour ca de lire les fichiers audio mais je
|
Derniers Blogs
SESSION SILVERLIGHT 5 3D : SLIDES ET DEMOSSESSION SILVERLIGHT 5 3D : SLIDES ET DEMOS par Groc
Durant les techdays, j'ai eu le plaisir d'animer une session sur Silverlight 5 et la 3D avec Simon Ferquel. Comme promis, voici nos slides et mes démos (celles avec le viper BSG) ici et là. Pour mémoire, les démos utilisent toutes le viper BSG...
Cliquez pour lire la suite de l'article par Groc [TECHDAYS 2012] SESSION WEBMATRIX 2 : LE COUTEAU SUISSE GRATUIT POUR VOS DéVELOPPEMENTS WEB - SLIDES[TECHDAYS 2012] SESSION WEBMATRIX 2 : LE COUTEAU SUISSE GRATUIT POUR VOS DéVELOPPEMENTS WEB - SLIDES par gpommier
Suite à la session que j'ai présenté sur WebMatrix 2, vous pouvez trouver les slides ici, ainsi que les démos en packages nuget : démos1 et démos2 J'en profite pour remercier chaleureusement tous ceux qui sont venus très nombreux à cette sess...
Cliquez pour lire la suite de l'article par gpommier [SHAREPOINT] LES SESSIONS TECHDAYS 2012.[SHAREPOINT] LES SESSIONS TECHDAYS 2012. par Patrick Guimonet
Voici donc pour ceux qui n'ont pas pu venir, ou ceux qui n'ont pas pu toutes les suivre la liste des sessions SharePoint aux TechDays 2012, que je mettrais à jour dès que les liens des vidéo seront disponibles. Ou ici : http...
Cliquez pour lire la suite de l'article par Patrick Guimonet TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3TECHDAYS PARIS 2012 : SESSION PLEINIèRE JOUR 3 par ROMELARD Fabrice
Speaker: Bernard Ourghanlian Cette session est comme chaque jour transmise en live par BrainSonic, et j'ai donc suivi cette troisième pleinière par ce moyen sur mon iPad . Elle est dédiée comme chaque année à la mise en perspective de l'é...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE !MISHRA READER : UN LECTEUR RSS TRèS ZUNE STYLE EN OPEN SOURCE ! par Vko
Hier durant une session dédiée aux Techdays 2012, j'ai eu le plaisir d'annoncer la sortie de la Béta 2 de Mishra Reader. C'est quoi ? Pour les utilisateurs, c'est une vraie expérience de lecture de flux RSS sur Windows. Rien à voir avec les produit...
Cliquez pour lire la suite de l'article par Vko
Logiciels
Tribler (2012)TRIBLER (2012)Tribler est un client pair à pair (P2P/Peer-to-Peer) open source avec la capacité de regarder des... Cliquez pour télécharger Tribler OneSwarm (2012)ONESWARM (2012)Le peer-to-peer qui protège votre vie privée, c'est OneSwarm.
Ce logiciel de peer-to-peer crypté... Cliquez pour télécharger OneSwarm PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V8.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning
|