读写配置文件


void CMy04261View::OnInitialUpdate()
{
    CView::OnInitialUpdate();

    m_nXPos = GetPrivateProfileInt(_T("SECTION 1"),     // 节名
                                    _T("XPos"),         // 项名
                                    0,                  // 没找到次项时的缺省返回值
                                    _T("D:\\vs2010_projects\\0426-1\\Debug\\test.ini"));    // 配置文件的路径

    m_nYPos = GetPrivateProfileInt(_T("SECTION 1"),
                                    _T("YPos"),
                                    0,
                                    _T("D:\\vs2010_projects\\0426-1\\Debug\\test.ini"));

    TCHAR szbuf[256] = {0};
    // 返回获取到的字符串的实际长度
    int len = GetPrivateProfileString(_T("SECTION 2"),  // 节名
                                _T("Text"),             // 项名
                                _T("No Text"),          // 没有找到此项时的返回值
                                szbuf,                  // 缓冲区
                                256,                    // 缓冲区长度
                                _T("D:\\vs2010_projects\\0426-1\\Debug\\test.ini"));        // 配置文件路径

    m_strText = szbuf;

    Invalidate();
}


void CMy04261View::OnIniWritexy()
{
    // 写配置文件基本相同,需要把数值类型的变量格式化成字符串在写
    CString str = _T("");

    str.Format(_T("%d"), m_nXPos / 2);
    WritePrivateProfileString(_T("SECTION 1"), _T("XPos"), str, 
        _T("D:\\vs2010_projects\\0426-1\\Debug\\test.ini"));

    str.Format(_T("%d"), m_nYPos / 2);
    WritePrivateProfileString(_T("SECTION 1"), _T("YPos"), str, 
        _T("D:\\vs2010_projects\\0426-1\\Debug\\test.ini"));

    str = _T("WriteText");
    WritePrivateProfileString(_T("SECTION 2"), _T("Text"), str, 
        _T("D:\\vs2010_projects\\0426-1\\Debug\\test.ini"));
}


void CMy04261View::OnIniSection()
{
    TCHAR lpReturnString[256] = {0};
    // 读取指定节名下的所有项,每一项用空格隔开
    int len = GetPrivateProfileSection(_T("SECTION 1"),
                                    lpReturnString,
                                    256,
                                    _T("D:\\vs2010_projects\\0426-1\\Debug\\test.ini"));

    m_strText = _T("");
    for(int i = 0; i < len; i++)
    {
        if(lpReturnString[i] != _T('\0'))
            m_strText += lpReturnString[i];
        else
            m_strText += _T("\r\n");
    }
    //m_strText = lpReturnString;
    // Invalidate();

    // asterisk 星号,加星号
    MessageBox(m_strText, _T("tip"), MB_OKCANCEL | MB_ICONASTERISK);

    memset(lpReturnString, _T('\0'), 256 * sizeof(TCHAR));

    // 读取配置文件中的所有节名
    len = GetPrivateProfileSectionNames(lpReturnString, 256, 
            _T("D:\\vs2010_projects\\0426-1\\Debug\\test.ini"));

    m_strText = _T("");
    for(int i = 0; i < len; i++)
    {
        if(lpReturnString[i] != _T('\0'))
            m_strText += lpReturnString[i];
        else
            m_strText += _T("\r\n");
    }

    MessageBox(m_strText, _T("tip"), MB_OKCANCEL | MB_ICONEXCLAMATION);
}

void CMy04261View::OnDraw(CDC* pDC)
{
    CMy04261Doc* pDoc = GetDocument();
    ASSERT_VALID(pDoc);
    if (!pDoc)
        return;

    pDC->TextOut(m_nXPos, m_nYPos, m_strText);
}


typedef struct _mytest
{
    int i;
    TCHAR a[30];
    double d;
}mytest;

void CMy04261View::OnIniWritestruct()
{
    mytest mystruct = {0};
    mytest myout;
    mystruct.i = 5;
    _tcscpy(mystruct.a, _T("liangjisheng"));
    mystruct.d = 5.06;

    bool bWrite = WritePrivateProfileStruct(_T("zheng"),
                                        _T("test"),
                                        (mytest *)&mystruct,
                                        sizeof(mystruct),
                                        _T("D:\\vs2010_projects\\0426-1\\Debug\\testStruct.ini"));
    if(bWrite)
    {
        bool bRead = GetPrivateProfileStruct(_T("zheng"),
                        _T("test"),
                        (mytest *)&myout,
                        sizeof(myout),
                        _T("D:\\vs2010_projects\\0426-1\\Debug\\testStruct.ini"));
        if(bRead)
        {
            CString str, strRet;
            str.Format(_T("Integer: %d\r\n"), myout.i);
            strRet = str;
            str.Format(_T("Double: %lf\r\n"), myout.d);
            strRet += str;
            str.Format(_T("Chars: %s"), myout.a);
            strRet += str;

            MessageBox(strRet, _T("tip"), MB_OKCANCEL | MB_ICONHAND);
        }
    }
}
纯c读写ini配置文件 用c/c++读写ini配置文件有不少第三方的开源库,如iniparser、libini、rwini、UltraLightINIParser等,但都不理想,往往代码较大、功能较弱、 接口使用不方便。尤其在大小写处理、前后空格、各种注释、跨平台换行符支持、带引号字符串处理、无section操作、原格式保持等方面存在问题。 现将本人精心制作的ini读写程序源码奉献给大家,纯c编写,简洁好用。支持windows和linux。 主要特点: 1、支持;和#注释符号,支持行尾注释。 2、支持带引号'或"成对匹配的字符串,提取时自动去引号。引号中可带其它引号或;#注释符。 3、支持无section或空section(名称为空)。 4、支持10、16、8进制数,0x开头为16进制数,0开头为8进制。 5、支持section、key或=号前后带空格。 6、支持\n、\r、\r\n或\n\r换行格式。 7、不区分section、key大小写,但写入时以新串为准,并保持其大小写。 8、新增数据时,若section存在则在该节最后一个有效数据后添加,否则在文件尾部添加。 9、支持指定key所在整行删除,即删除该键值,包括注释。 10、可自动跳过格式错误行,修改时仍然保留。 11、修改时保留原注释:包括整行注释、行尾注释(包括前面空格)。 12、修改时保留原空行。以上三点主要是尽量保留原格式。 不足之处: 1、不支持单key多value(逗号分割),只能一次性提取后自行处理。 2、不支持同名重复section和key。(重复section可视为错误,重复key则可能造成分歧) 3、不能提取所有section或key名称。 使用只需两个文件inirw.h、inirw.c,另有测试程序和工程文件,支持windows和linux。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值