J'ai une variable GUID et je veux écrire sa valeur dans un fichier texte. La définition du GUID est:
typedef struct _GUID { // size is 16
DWORD Data1;
Word Data2;
Word Data3;
BYTE Data4[8];
} GUID;
Mais je veux écrire sa valeur comme:
CA04046D-0000-0000-0000-504944564944
J'ai observé que:
Data1
contient la valeur décimale pour CA04046DData2
contient la valeur décimale pour 0Data3
conserve la valeur décimale pour le prochain 0Mais qu'en est-il des autres?
Je dois m'interpréter moi-même ces valeurs pour obtenir cette sortie ou existe-t-il une méthode plus directe pour imprimer une telle variable?
Utilisez la fonction StringFromCLSID pour le convertir en chaîne
par exemple.:
GUID guid;
CoCreateGuid(&guid);
OLECHAR* guidString;
StringFromCLSID(guid, &guidString);
// use guidString...
// ensure memory is freed
::CoTaskMemFree(guidString);
Voir également la définition MSDN d'un GUID pour une description de data4, qui est un tableau contenant les 8 derniers octets du GUID.
Parfois, il est utile de rouler le vôtre. J'ai aimé la réponse de fdioff mais ce n'est pas tout à fait correct. Il y a 11 éléments de tailles différentes.
printf("Guid = {%08lX-%04hX-%04hX-%02hhX%02hhX-%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX}",
guid.Data1, guid.Data2, guid.Data3,
guid.Data4[0], guid.Data4[1], guid.Data4[2], guid.Data4[3],
guid.Data4[4], guid.Data4[5], guid.Data4[6], guid.Data4[7]);
Output: "Guid = {44332211-1234-ABCD-EFEF-001122334455}"
Reportez-vous à Guiddef.h pour la mise en page GUID.
Idem, comme méthode:
void printf_guid(GUID guid) {
printf("Guid = {%08lX-%04hX-%04hX-%02hhX%02hhX-%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX}",
guid.Data1, guid.Data2, guid.Data3,
guid.Data4[0], guid.Data4[1], guid.Data4[2], guid.Data4[3],
guid.Data4[4], guid.Data4[5], guid.Data4[6], guid.Data4[7]);
}
vous pouvez également passer un CLSID à cette méthode.
Si votre code utilise ATL/MFC, vous pouvez également utiliser CComBSTR::CComBSTR(REFGUID guid)
from atlbase.h
:
GUID guid = ...;
const CComBSTR guidBstr(guid); // Converts from binary GUID to BSTR
const CString guidStr(guidBstr); // Converts from BSTR to appropriate string, ANSI or Wide
La conversion et le nettoyage de la mémoire seront automatiquement effectués.
Si vous préférez C++
std::ostream& operator<<(std::ostream& os, REFGUID guid){
os << std::uppercase;
os.width(8);
os << std::hex << guid.Data1 << '-';
os.width(4);
os << std::hex << guid.Data2 << '-';
os.width(4);
os << std::hex << guid.Data3 << '-';
os.width(2);
os << std::hex
<< static_cast<short>(guid.Data4[0])
<< static_cast<short>(guid.Data4[1])
<< '-'
<< static_cast<short>(guid.Data4[2])
<< static_cast<short>(guid.Data4[3])
<< static_cast<short>(guid.Data4[4])
<< static_cast<short>(guid.Data4[5])
<< static_cast<short>(guid.Data4[6])
<< static_cast<short>(guid.Data4[7]);
os << std::nouppercase;
return os;
}
Usage:
static const GUID guid =
{ 0xf54f83c5, 0x9724, 0x41ba, { 0xbb, 0xdb, 0x69, 0x26, 0xf7, 0xbd, 0x68, 0x13 } };
std::cout << guid << std::endl;
Sortie:
F54F83C5-9724-41BA-BBDB-6926F7BD6813
Inspiré par JustinB 's answer
#define GUID_FORMAT "%08lX-%04hX-%04hX-%02hhX%02hhX-%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX"
#define GUID_ARG(guid) guid.Data1, guid.Data2, guid.Data3, guid.Data4[0], guid.Data4[1], guid.Data4[2], guid.Data4[3], guid.Data4[4], guid.Data4[5], guid.Data4[6], guid.Data4[7]
et alors
printf("Int = %d, string = %s, GUID = {" GUID_FORMAT "}\n", myInt, myString, GUID_ARG(myGuid));
Vous pouvez éliminer le besoin d'allocations/désallocations de chaînes spéciales en utilisant StringFromGUID2 ()
GUID guid = <some-guid>;
// note that OLECHAR is a typedef'd wchar_t
wchar_t szGUID[64] = {0};
StringFromGUID2(&guid, szGUID, 64);
Gracieuseté de cassette Google projet
std::string ToString(GUID *guid) {
char guid_string[37]; // 32 hex chars + 4 hyphens + null terminator
snprintf(
guid_string, sizeof(guid_string) / sizeof(guid_string[0]),
"%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x",
guid->Data1, guid->Data2, guid->Data3,
guid->Data4[0], guid->Data4[1], guid->Data4[2],
guid->Data4[3], guid->Data4[4], guid->Data4[5],
guid->Data4[6], guid->Data4[7]);
return guid_string;
}
UUID guid = {0};
UuidCreate(&guid);
std::cout << GUIDToString(&guid);
Je sais que la question est assez ancienne, mais cela fonctionnerait-il peut-être?
inline std::ostream& operator <<(std::ostream& ss,GUID const& item) {
OLECHAR* bstrGuid;
::StringFromCLSID(item, &bstrGuid);
ss << bstrGuid;
::CoTaskMemFree(bstrGuid);
return ss;
}
Utilisez UuidToString function pour convertir GUID en chaîne. La fonction accepte le type UUID qui est typedef of GUID.
std::string
GuidToString(const GUID& guid, bool lower = false)
{
const char* hexChars = lower ? "0123456789abcdef" : "0123456789ABCDEF";
auto f = [hexChars](char* p, unsigned char v)
{
p[0] = hexChars[v >> 4];
p[1] = hexChars[v & 0xf];
};
char s[36];
f(s, static_cast<unsigned char>(guid.Data1 >> 24));
f(s + 2, static_cast<unsigned char>(guid.Data1 >> 16));
f(s + 4, static_cast<unsigned char>(guid.Data1 >> 8));
f(s + 6, static_cast<unsigned char>(guid.Data1));
s[8] = '-';
f(s + 9, static_cast<unsigned char>(guid.Data2 >> 8));
f(s + 11, static_cast<unsigned char>(guid.Data2));
s[13] = '-';
f(s + 14, static_cast<unsigned char>(guid.Data3 >> 8));
f(s + 16, static_cast<unsigned char>(guid.Data3));
s[18] = '-';
f(s + 19, guid.Data4[0]);
f(s + 21, guid.Data4[1]);
s[23] = '-';
f(s + 24, guid.Data4[2]);
f(s + 26, guid.Data4[3]);
f(s + 28, guid.Data4[4]);
f(s + 30, guid.Data4[5]);
f(s + 32, guid.Data4[6]);
f(s + 34, guid.Data4[7]);
return std::string(s, 36);
}