Rechercher : dans
Par :

[php] convertion d'une chaine de caractere

Dernière réponse le 22 aoû 2008 à 14:58:15 Nico, le 13 jun 2005 à 15:56:37 
 Signaler ce message aux modérateurs

Bonjour,
Je sui entrain de créer un petit site php/html utilisant une base acces.
A l'interieur d'une requete je souhaiterais convertir un format chaine de caractere en numérique.
La fonction TO_NUMBET(chaine) n' a pas l'aire de fontionner sous access.
Faute d'avoir trouver reponse quelque part, j'espere que vous pourrez m'aider.
Merci

Meilleures réponses pour « [php] convertion d'une chaine de caractere » dans :
PHP - Nettoyer une chaîne de caractères VoirVoici une fonction en PHP qui peut être assez pratique, surtout quand on fait de l'URL Rewriting. Cette fonction permet de transformer les caractères de n'importe quelle chaîne de caractères en chaîne non accentuée, en enlevant les caractères...
Utiliser des accents et autres caractères spéciaux VoirDans la plupart des langages de programmation, on ne peut utiliser directement les accents et autres caractères non-anglosaxon. La solution est l'unicode, une sorte de code universel. Par exemple pour afficher la chaine de caractères : " là, ça...
Langage C - Les chaînes de caractères VoirQu'est-ce qu'une chaîne de caractères ? Une chaîne de caractères (appelée string en anglais) est une suite de caractères, c'est-à-dire un ensemble de symboles faisant partie du jeu de caractères, défini par le code ASCII. En langage C, une chaîne...
PHP - Expressions régulières VoirQu'est-ce qu'une expression régulière? Les expressions régulières sont des modèles créés à l'aide de caractères ASCII permettant de manipuler des chaînes de caractères, c'est-à-dire permettant de trouver les portions de la chaîne correspondant au...
Les chaînes de caractères en C++ VoirQu'est-ce qu'une chaîne de caractères ? Une chaîne de caractères (appelée string en anglais) est une suite de caractères, c'est-à-dire un ensemble de symboles faisant partie du jeu de caractères, défini par le code ASCII. En langage C++, une...

1

nauno, le 13 jun 2005 à 16:37:00

En 30s de reflexion je dirai kil fodrai s'amuser avec les codes ASCII et un fichier
mais j'accorde ke ya peut-etre meme certainement plus simple!!!

Répondre à nauno

2

kilian, le 13 jun 2005 à 16:45:16

Euh, j'ai du mal à comprendre.
Tu pourrais nous mettre un exemple?

Répondre à kilian

3

nauno, le 13 jun 2005 à 16:52:55

Kom je disais c'était en 30s de réflexion après 5min j'en pas la moindre idée et le coup du code ASCII je le sens pas du tout
ca m'apprendra a pas parler trop vite

Répondre à nauno

4

kilian, le 13 jun 2005 à 16:57:20

Non non je crois que tu peux transformer un caractère en son code ascii en php. En fait je posais ma question à Nico :-)

Mais je suppose qu'il veut transformer une chaine de caractère, composée de chiffres, en valeur numerique...M'enfin justement c'est ça que j'ai pas bien compris....

Répondre à kilian

5

nico, le 13 jun 2005 à 16:57:46

Pour etre plus precis je fait en fete une requete sur le mois:
$req="select mois from planning
group by mois
order by mois";
Le probleme ici c'est que le createur de la base de donnée access a entré les mois comme valeur "text".
J'obtient donc les mois ordonnés ainsi:
1 ,10 , 11, 12, 2, 3, 4, 5, 6, 7, 8, 9
N'ayant pas le droit de modifié la base access je pense q'ui faudrait convertir le format de 'mois' dans la requete.
En esperant avoir été plus clair, merci d'avance

Répondre à nico

6

nauno, le 13 jun 2005 à 17:02:21

Dans ce cas essaye

ORDER BY mois ASC

pluto ke
order by mois"; 


c'est sensé faire un tri alphanumérique essaye et tu verra bien si ca marche

heu pour le coup du code ASCII oui on peut mais t'alucine le bordel ke c'est

Répondre à nauno

9

kilian, le 13 jun 2005 à 17:06:51

heu pour le coup du code ASCII oui on peut mais t'alucine le bordel ke c'est


Heu bah non... :-)
http://fr2.php.net/manual/fr/function.ord.php

Répondre à kilian

7

kilian, le 13 jun 2005 à 17:02:41

Mais il sera stocké comme etant un "text" de toute façon.
Sauf erreur de ma part, je ne pense pas que çe soit fiable.

Ceci dis tu peux organiser tes valeurs après la requete...(au niveau Php)...

Répondre à kilian

8

nauno, le 13 jun 2005 à 17:06:13

Oui sa reste du txt mais dans tout les cas c'est pareil ca ne l'empeche pas de faire des opérations dessus

Répondre à nauno

10

kilian, le 13 jun 2005 à 17:09:20

Voui... Chais pas faut voir, je m trompe peut êtr mais je pense que ce sera traité comme des chaines.
D'où le classement bizzare qui resulte de sa requête.

Répondre à kilian

11

nauno, le 13 jun 2005 à 17:11:44

Le mieux c'est encore d'attendre ce ke le mr en pense

Répondre à nauno

12

Nico, le 13 jun 2005 à 17:13:51

Tout d'abord merci de toute vos reponses.
Le 'order by asc' reste cependant inéficace...
Quand au traitement dans la page j'y avait penser mais il risque de rendre le reste du code encore plus complexe sachant que j'ai deja eu pas mal de difficulté :/

Répondre à Nico

13

nauno, le 13 jun 2005 à 17:19:15

Mais au juste tu veux faire koi???
-les ordonner dans l'ordre numerique
-les transformer en nombre pour pouvoir faire sais pas koi!

Répondre à nauno

14

Nico, le 13 jun 2005 à 17:24:07

Désolée je pensais avoir été suffisament clair
je souhaite les ordonnés oui
mais cela me parait difficile sans les convertir prealablement au format numerique.

Répondre à Nico

15

nauno, le 13 jun 2005 à 17:39:27

Le transtypage
Le transtypage désigne l'action de convertir un type de données en un autre. Ici, il peut servir en plus à définir explicitement le type d'une donnée. La façon d'opérer est exactement la même qu'en C:

$UnEntier = (int) "4320Pastèque";
Ici, au lieu de créer une chaine, PHP va, grâce au "(int)", créer un entier qui aura pour valeur 4320.

Voici les opérateurs de trantypage du PHP:
(int), (integer): Conversion en entier
(real), (double), (float): Conversion en nombre décimal
(string): Conversion en chaine
(array): Conversion en tableau
(object): Conversion en objet
Le PHP propose des fonctions qui permettent de vérifier le type d'une variable: is_int(), is_float(), is_double(), is_array(), is_string(), is_object(), etc...


j'ai trouver sur http://www.mangue.org/e107_plugins/cours/cours.php?id=php&cid=cours2.html

Répondre à nauno

16

nauno, le 13 jun 2005 à 17:40:07

Je ne pense pas ke je pourrai fairee mieux bonne chance

Répondre à nauno

17

lysandre, le 21 sep 2007 à 20:18:07

L'histoire du transtypage ne marche pas, en tout cas pas comme ca. Tout ce qui se passe ici est que seuls les caracteres etant des chiffres sont considérés. (int) "mot" donne tjs 0. Pour le TO_NUMBET ca doit plutot etre TO_NUMBER non? Mais de toute facon aucun des deux ne marche sous php. Je fais une petite recherche rapide et je vous dis si je trouve qqch.

Répondre à lysandre

18

lysandre, le 21 sep 2007 à 21:06:07

Intval("0123456789abcdefghijklmnopqrstuvwxyz",36)

interprete les chaines de caractere comme des nombres en base 36 (chiffres de 0 a z) et le retourne en base 10. Par contre ca ne marche que pour les chaines contenant des chiffres et les lettres de l'alphabet. Ca ne marche pas en base >36 (et non, on peut pas utiliser les autres caracteres comme ca)

Répondre à lysandre

19

mamoud, le 1 jui 2008 à 16:58:58

J'ai une chaîne des caratères contenant des chiffres et je veut la convertir en entier

Répondre à mamoud

20

 Tof, le 22 aoû 2008 à 14:58:15

Tout simplement en SQL :

SELECT LPAD(mois,2,'0') AS 'mois_reformate' FROM matable ORDER BY mois_reformate

LPAD complete à gauche jusqu'a le nombre de caracteres désignés par le caractere fournis en 3eme parametre

1 -> 01
...

11 -> 11
12 -> 12

et donc le ORDER BY fonctionne correctement

Répondre à Tof