如何获得INI文件的节数,键名数,键数

zy2015036 2013-01-25 01:38:39
请教各位高手
如何获得INI文件的节数,键名数,键数
谢谢.
...全文
730 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
「已注销」 2013-01-26
  • 打赏
  • 举报
回复
定义的一个ListCtl,传进来的指针
引用 9 楼 zy2015036 的回复:
引用 7 楼 ptjian 的回复:C/C++ code?123456789101112131415#define MAX_SECTION 1000//section的最大字长度wchar_t filetemp[MAX_PATH + 1]; ::GetCurrentDirectory(MAX_PATH,filetemp);//取当前路径 wcscat(file……
  • 打赏
  • 举报
回复
顶一下 哈哈
zy2015036 2013-01-25
  • 打赏
  • 举报
回复
引用 7 楼 ptjian 的回复:
C/C++ code?123456789101112131415#define MAX_SECTION 1000//section的最大字长度wchar_t filetemp[MAX_PATH + 1]; ::GetCurrentDirectory(MAX_PATH,filetemp);//取当前路径 wcscat(filetemp,L"\\setup.ini……
m_funcNameList 是怎么定义的?
「已注销」 2013-01-25
  • 打赏
  • 举报
回复
#define MAX_SECTION 1000//section的最大字长度
wchar_t filetemp[MAX_PATH + 1];
	::GetCurrentDirectory(MAX_PATH,filetemp);//取当前路径
	wcscat(filetemp,L"\\setup.ini");//配置文件

	wchar_t configStr[MAX_SECTION + 1];
	DWORD sectionNum = GetPrivateProfileString(NULL,NULL,L"",configStr,MAX_SECTION,filetemp);//读取所有的section保存,section之间用NULL隔开
	int posNum = 0;//标记遍历字符串时NULL的位置
	wchar_t *temp = configStr + posNum;
	for(posNum; posNum < sectionNum;)//configStr以两个NULL作为结束
	{
		m_funcNameList->AddString(temp);
		posNum += wcslen(temp) + 1;
		temp = configStr + posNum ;
	}
代码不好,莫笑
引用 6 楼 tiger9991 的回复:
如果ini是自己写的,总数还是自己搞个键数统计一下。 API没有直接提供接口,要自己遍历和解析。
看不见的裂痕 2013-01-25
  • 打赏
  • 举报
回复
如果ini是自己写的,总数还是自己搞个键数统计一下。 API没有直接提供接口,要自己遍历和解析。
Eleven 2013-01-25
  • 打赏
  • 举报
回复
GetPrivateProfileSection/GetPrivateProfileSectionNames
shn521 2013-01-25
  • 打赏
  • 举报
回复
http://download.csdn.net/download/mail_cm/4023315
快乐鹦鹉 2013-01-25
  • 打赏
  • 举报
回复
遍历一遍就可以了吧
步履人生 2013-01-25
  • 打赏
  • 举报
回复
#define MAX_BUFFER	1024	//the buffer for "String" or "SectionNames" return 

CString CIniEntry::GetString(LPCTSTR lpIniFileName,LPCTSTR lpSectionName, LPCTSTR lpKeyName)
{
	LPCTSTR lpDefault="";
	char RetString[MAX_BUFFER]="\0";

	LPTSTR lpRetString=RetString;
	DWORD dwChar;

	dwChar=GetPrivateProfileString(lpSectionName,lpKeyName,lpDefault,lpRetString,
		sizeof(RetString),lpIniFileName);
	if(!dwChar)
		return "";
	return (CString)lpRetString;
}


BOOL CIniEntry::WriteString(LPCTSTR lpIniFileName, LPCTSTR lpSectionName, LPCTSTR lpKeyName, LPCTSTR lpString)
{
	ASSERT(lpIniFileName);

	if(!lpSectionName)
		return FALSE;

	return(::WritePrivateProfileString(lpSectionName,lpKeyName,lpString,lpIniFileName));

}

CString CIniEntry::EnumSectionNames(LPCTSTR lpIniFileName,char chSpaceSign)
{
	ASSERT(lpIniFileName);

	if(!lpIniFileName)
		return "";
	
	DWORD dwSize;
	char tsn[MAX_BUFFER]="\0";
	LPTSTR lptsn=tsn;
	CString strSn;

	dwSize=::GetPrivateProfileSectionNames(lptsn,sizeof(tsn),lpIniFileName);
	DWORD dwI=dwSize-2;

	if(dwSize)
	{
		char sn[MAX_BUFFER]="\0";

		strncpy(sn,&tsn[0],1);
		for(DWORD i=1;i<dwI;i++)
		{
			if(tsn[i])
				strncat(sn,&tsn[i],1);
			else
				strncat(sn,&chSpaceSign,1);
		}
		if(dwSize==MAX_BUFFER-2)
			AfxMessageBox("Not All of the Sections Returned!",MB_ICONINFORMATION|MB_OK);
		strSn=(CString) sn;
		return strSn;
	}
	
	return "";
}


CString CIniEntry::GetSection(LPCTSTR lpIniFileName, LPCTSTR lpSectionName,char chSpaceSign)
{
	ASSERT(lpIniFileName);
	ASSERT(lpSectionName);
	if(!lpSectionName||!lpIniFileName)
		return "";

	char tkn[MAX_BUFFER]="\0";
	LPTSTR lptkn=tkn;
	DWORD dwSize,dwI;
	CString strSection;

	dwSize=::GetPrivateProfileSection(lpSectionName,lptkn,sizeof(tkn),lpIniFileName);
	
	dwI=dwSize-2;
	if(dwSize)
	{
		char kn[MAX_BUFFER]="\0";

		strncpy(kn,&tkn[0],1);
		for(DWORD i=1;i<dwI;i++)
		{
			if(tkn[i])
				strncat(kn,&tkn[i],1);
			else
				strncat(kn,&chSpaceSign,1);
		}
		if(dwSize==MAX_BUFFER-2)
			AfxMessageBox("Not All of the Keys Returned!",MB_ICONINFORMATION|MB_OK);
		strSection=(CString) kn;
		return strSection;
	}
	return "";
}

CString CIniEntry::EnumKeys(LPCTSTR lpIniFileName, LPCTSTR lpSectionName,char chSpaceSign)
{
	CString strKn;
	strKn=GetSection(lpIniFileName,lpSectionName,chSpaceSign);
	if(!strKn.IsEmpty())
	{
		CString kn;

		int dwSize=strKn.GetLength();
		
		// Find the first key of the section (before the first "=");
		int nEqual=strKn.Find('=');	// Index of the "=";
		kn=strKn.Left(nEqual);

		int nPos=nEqual+1;
		//t1=12345,t2=67890,t3=fffff,t4=aaaaa,t5=asss
		while((nEqual=strKn.Find('=',nPos))!=-1)
		{
			kn+=chSpaceSign;
			int nSpaceSign=strKn.Find(chSpaceSign,nPos);
			kn+=strKn.Mid(nSpaceSign+1,nEqual-nSpaceSign-1);
			nPos=nEqual+1;
		}
		return kn;
	}
	return "";
}
步履人生 2013-01-25
  • 打赏
  • 举报
回复
#define MAX_BUFFER	1024	//the buffer for "String" or "SectionNames" return 

CString CIniEntry::GetString(LPCTSTR lpIniFileName,LPCTSTR lpSectionName, LPCTSTR lpKeyName)
{
LPCTSTR lpDefault="";
char RetString[MAX_BUFFER]="\0";

LPTSTR lpRetString=RetString;
DWORD dwChar;

dwChar=GetPrivateProfileString(lpSectionName,lpKeyName,lpDefault,lpRetString,
sizeof(RetString),lpIniFileName);
if(!dwChar)
return "";
return (CString)lpRetString;
}


BOOL CIniEntry::WriteString(LPCTSTR lpIniFileName, LPCTSTR lpSectionName, LPCTSTR lpKeyName, LPCTSTR lpString)
{
ASSERT(lpIniFileName);

if(!lpSectionName)
return FALSE;

return(::WritePrivateProfileString(lpSectionName,lpKeyName,lpString,lpIniFileName));

}

CString CIniEntry::EnumSectionNames(LPCTSTR lpIniFileName,char chSpaceSign)
{
ASSERT(lpIniFileName);

if(!lpIniFileName)
return "";

DWORD dwSize;
char tsn[MAX_BUFFER]="\0";
LPTSTR lptsn=tsn;
CString strSn;

dwSize=::GetPrivateProfileSectionNames(lptsn,sizeof(tsn),lpIniFileName);
DWORD dwI=dwSize-2;

if(dwSize)
{
char sn[MAX_BUFFER]="\0";

strncpy(sn,&tsn[0],1);
for(DWORD i=1;i<dwI;i++)
{
if(tsn[i])
strncat(sn,&tsn[i],1);
else
strncat(sn,&chSpaceSign,1);
}
if(dwSize==MAX_BUFFER-2)
AfxMessageBox("Not All of the Sections Returned!",MB_ICONINFORMATION|MB_OK);
strSn=(CString) sn;
return strSn;
}

return "";
}


CString CIniEntry::GetSection(LPCTSTR lpIniFileName, LPCTSTR lpSectionName,char chSpaceSign)
{
ASSERT(lpIniFileName);
ASSERT(lpSectionName);
if(!lpSectionName||!lpIniFileName)
return "";

char tkn[MAX_BUFFER]="\0";
LPTSTR lptkn=tkn;
DWORD dwSize,dwI;
CString strSection;

dwSize=::GetPrivateProfileSection(lpSectionName,lptkn,sizeof(tkn),lpIniFileName);

dwI=dwSize-2;
if(dwSize)
{
char kn[MAX_BUFFER]="\0";

strncpy(kn,&tkn[0],1);
for(DWORD i=1;i<dwI;i++)
{
if(tkn[i])
strncat(kn,&tkn[i],1);
else
strncat(kn,&chSpaceSign,1);
}
if(dwSize==MAX_BUFFER-2)
AfxMessageBox("Not All of the Keys Returned!",MB_ICONINFORMATION|MB_OK);
strSection=(CString) kn;
return strSection;
}
return "";
}

CString CIniEntry::EnumKeys(LPCTSTR lpIniFileName, LPCTSTR lpSectionName,char chSpaceSign)
{
CString strKn;
strKn=GetSection(lpIniFileName,lpSectionName,chSpaceSign);
if(!strKn.IsEmpty())
{
CString kn;

int dwSize=strKn.GetLength();

// Find the first key of the section (before the first "=");
int nEqual=strKn.Find('='); // Index of the "=";
kn=strKn.Left(nEqual);

int nPos=nEqual+1;
//t1=12345,t2=67890,t3=fffff,t4=aaaaa,t5=asss
while((nEqual=strKn.Find('=',nPos))!=-1)
{
kn+=chSpaceSign;
int nSpaceSign=strKn.Find(chSpaceSign,nPos);
kn+=strKn.Mid(nSpaceSign+1,nEqual-nSpaceSign-1);
nPos=nEqual+1;
}
return kn;
}
return "";
}
打开链接下载源码: https://pan.quark.cn/s/a4b39357ea24 在Qt框架中,QSerialPort类被视为一个关键组件,用于执行与串行端口之间的通信任务,它具备多样化的功能,涵盖了串口的开启与关闭操作,以及波特率、据位、停止位和奇偶校验等参的设定,同时还包括据的发送和接收功能。在标题和描述中提及的“Qt5的QSerialPort类通过信号槽实现串口读写”,这代表了一种在Qt编程中普遍采用的事件驱动策略,借助信号槽机制,能够便捷地管理串口据的传输与接收。 1. **QSerialPort类的基础操作**: - 初始化阶段:必须构建一个QSerialPort实例,并为其指定串口名称,例如"/dev/ttyUSB0"。 - 参配置:利用`setPortName()`、`setBaudRate()`、`setDataBits()`、`setParity()`、`setStopBits()`、`setFlowControl()`等方法,依据具体需求对串口参进行配置。 - 串口开启/终止:借助`open()`方法启动串口,通过`close()`方法终止串口。务必验证`isOpen()`的返回状态,以确保操作的有效性。 2. **信号槽机制的应用**: - 信号的生成:QSerialPort类中定义了若干信号,诸如`readyRead()`表明有据可读,`error()`指示出现错误,`bytesWritten()`显示据已传输等。当这些事件发生时,将触发相应的信号。 - 槽函的关联:相应地,可以将这些信号与自定义的槽函相连接,比如,当`readyRead()`信号被激活时,可以调用一个用于处理读取据的函。 3. **串口据...

16,550

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧