Я хочу создать файл с помощью команд sql:
CREATE TABLE t1(a INTEGER, b INTEGER, c VARCHAR(100));
INSERT INTO t1 VALUES(1,13153,'thirteen thousand one hundred fifty three');
INSERT INTO t1 VALUES(2,75560,'seventy five thousand five hundred sixty');
... 995 lines omitted
INSERT INTO t1 VALUES(998,66289,'sixty six thousand two hundred eighty nine');
INSERT INTO t1 VALUES(999,24322,'twenty four thousand three hundred twenty two');
INSERT INTO t1 VALUES(1000,94142,'ninety four thousand one hundred forty two');
Это работает, когда я использую printf:
printf("INSERT INTO t1 VALUES(%d, %d, '", i, nbAlea);
NombreVersMots(nbAlea);
printf("');\n");
Но я не могу использовать fprintf:
fprintf(fichier, "INSERT INTO t1 VALUES(%d, %d, '", i, nbAlea);
fprintf(fichier, NombreVersMots(nbAlea)); // <- HERE IS MY PROBLEM
fprintf(fichier, "');\n");
Я не нахожу способ использовать вторую строку.
Я даю вам необходимые вам процедуры:
char *one[]={"", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "ten", "eleven", "twelve", "thirteen", "fourteen", "fifteen", "sixteen", "seventeen", "eighteen", "nineteen"};
char *ten[]={"", "", "twenty", "thirty", "forty", "fifty", "sixty", "seventy", "eighty", "ninety"};
void pw(long n,char ch[])
{
if(n>19)
{
printf("%s %s ",ten[n/10],one[n%10]);
}
else
{
if(n) // pour eviter les espaces inutiles quand la boucle n'affiche rien
{
printf("%s ",one[n]);
}
}
if(n)
{
printf("%s",ch); // affiche 'million', 'thousand' ou 'hundred'
}
}
void NombreVersMots(long m)
{
pw((m/1000000), "million ");
pw(((m/100000)%10), "hundred ");
pw(((m/1000)%100), "thousand ");
pw(((m/100)%10), "hundred ");
pw(((m/1)%100), "");
}
Большое спасибо, если вы можете мне помочь!