Précédent   Forum des professionnels en informatique > Systèmes > Linux > Applications > Shell
Shell Vos questions sur l'utilisation des commandes shell
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 07/09/2004, 12h21   #1
Rédacteur/Modérateur
 
Avatar de orafrance
 
Inscription : janvier 2004
Messages : 15 861
Détails du profil
Informations personnelles :
Âge : 35

Informations forums :
Inscription : janvier 2004
Messages : 15 861
Points : 16 212
Points : 16 212
Par défaut Compter le nombre de champs (cut ?)

bonjour,

je suis en train de me battre pour essayer de compter le nombre de champs d'une ligne avec un séparateur

Ex :
toto;titi;; 3 champs (dont un vide )
toto;tata;tutu;titi 4 champs.

J'avais espérer que cut retourne une erreur quand on demande un numéro de champ inexistant mais non... on a juste un résultat vide

Merci pour votre aide
orafrance est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/09/2004, 12h40   #2
Modérateur
 
Avatar de ggnore
 
Inscription : juillet 2004
Messages : 2 245
Détails du profil
Informations personnelles :
Âge : 33

Informations forums :
Inscription : juillet 2004
Messages : 2 245
Points : 1 902
Points : 1 902
wc ?
ggnore est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/09/2004, 12h41   #3
Membre du Club
 
Inscription : juin 2004
Messages : 39
Détails du profil
Informations forums :
Inscription : juin 2004
Messages : 39
Points : 40
Points : 40
oui wc en definissant le separateur

man wc
vi4ever est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 07/09/2004, 14h37   #4
Rédacteur/Modérateur
 
Avatar de orafrance
 
Inscription : janvier 2004
Messages : 15 861
Détails du profil
Informations personnelles :
Âge : 35

Informations forums :
Inscription : janvier 2004
Messages : 15 861
Points : 16 212
Points : 16 212
ha bah oui

je croyais que ça ne comptais que les lignes

Merci
orafrance est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/05/2007, 07h50   #5
Invité de passage
 
Inscription : mai 2007
Messages : 3
Détails du profil
Informations forums :
Inscription : mai 2007
Messages : 3
Points : 1
Points : 1
Par défaut PHP SQL Champ

Bonjour,

je me suis interressé à ce message car j'ai moi même un problème concernant mysql.

Voici le topo, j'ai une base avec 2 champs (année et mois) et 3 enregistrements :
2007, avril
2007, mai
2008, avril

J'aimerais créer un menu déroulant avec les enregistrements du champ 'année' c'est à dire avoir un menu déroulant avec indiqué à l'intérieur (2007,2008).

J'ai fais une requete sql pour lister ma base de donnée et j'obtiens des résultats, malheureusement mon menu déroulant affiche (2007,2007,2008) (du fait que j'ai 3 enregistrements, cela s'explique).

Ma question est la suivante : Comment lister une base de donnée et n'afficher que des valeurs différents (c'est à dire 2007,2008 et non 2007,2007,2008) ?

Pour vous aider, voici mon code :
Code PHP :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
 
<?
//connexion à ma base de donnée
	mysql_connect("****", "*****", "******");
	mysql_select_db("*****");
 
//on liste la base de donnée
	$reponse = mysql_query("SELECT * FROM base");
 
//On créer le menu déroulant et on liste la base de donnée
?>
 
<select size="1" name="Menu">
	<?
		while ($donnees = mysql_fetch_array($reponse) )
			{
				?>
					<option><?php echo $donnees['année']; ?></option>
				<?
			}
	?>
</selected>
Vantales est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 08/05/2007, 13h46   #6
Membre expérimenté
 
Avatar de BlaireauOne
 
Inscription : mars 2007
Messages : 469
Détails du profil
Informations personnelles :
Localisation : France, Haute Garonne (Midi Pyrénées)

Informations forums :
Inscription : mars 2007
Messages : 469
Points : 576
Points : 576
Citation:
Envoyé par orafrance
Nombre de champs d'une ligne avec un séparateur

Ex :
toto;titi;; 3 champs (dont un vide )
toto;tata;tutu;titi 4 champs.

Selon moi, les 2 enregs ci-dessus contiennent chacun 4 champs.
Le 1er contient 4 champs dont les 2 derniers sont vides.

Si tu veux gérer le cas d'enregs mal structurés (plus ou moins de 4 champs) et le test de champ(s) vide(s), solution suivante :

Exemple de fichier :
toto;tutu;
toto;titi;;
toto;tata;tutu;titi


Script awk :
http://lea-linux.org/cached/index/Dev-awk.html#
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
 
awk -F";" '
{
	if (NF != 4) {
		print "*** sur Record "NR" : "NF" champs presents !!!" | "cat 1>&2"
		next
	}
	if ($4 == "") {
		print "*** sur Record "NR" : champs n° 4 vide !!!" | "cat 1>&2"
		next
	}
	print $0 
} '  test.txt > result.txt

Message sur la sortie d'erreur (stderr) :
*** sur Record 1 : 3 champs presents !!!
*** sur Record 2 : champs n° 4 vide !!!


result.txt :
toto;tata;tutu;titi
BlaireauOne est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 23h37.


 
 
 
 
Partenaires

Hébergement Web