首页
学习
活动
专区
圈层
工具
发布

中的UTF8
EN

Stack Overflow用户
提问于 2016-12-11 08:45:05
回答 2查看 269关注 0票数 0

我正在尝试通过php将数据从xls导入到mysql。我面临的问题,在保存UTF-8文本通过它。我要将它保存为我的数据库表结构也是utf8_general_ci,我的php代码如下所示

代码语言:javascript
复制
 <?php 
    $con = mysqli_connect('localhost', 'myuser', 'mypass', 'mydb');


    if(isset($_POST["submit"]))
    {
    mysqli_query($con,'SET character_set_results=utf8');
    mysqli_query($con,'SET names=utf8');
    mysqli_query($con,'SET character_set_client=utf8');
    mysqli_query($con,'SET character_set_connection=utf8');
    mysqli_query($con,'SET character_set_results=utf8');
    mysqli_query($con,'SET collation_connection=utf8_general_ci');
    $file = $_FILES['file']['tmp_name'];
    $handle = fopen($file, "r");
    $i = 0;
    while(($filesop = fgetcsv($handle, 1000, ",")) !== false)
    {	
    $option1 = $filesop[0];
    $option2 = $filesop[1];
    $option3 = $filesop[2];
    $option4 = $filesop[3];
    $correctans = $filesop[4];
    $question_text = $filesop[5];
    $cat_id = $filesop[6];
    $sub_cat_id = $filesop[7];
    $level_id = $filesop[8];
    $quesimage = $filesop[9];

    $sql = mysqli_query($con,"INSERT IGNORE INTO questions (option1, option2,option3,option4,correctans,question_text,cat_id,sub_cat_id,level_id,quesimage) VALUES ('".$option1."','".$option2."','".$option3."','".$option4."','".$correctans."','".$question_text."','".$cat_id."','".$sub_cat_id."','".$level_id."','".$quesimage."')");
    $i = $i + 1;
    	
    }
    //echo $sql;
    if($sql)
    {
    echo "You database has imported successfully. You have inserted ". $i ." records";
    }
    else
    {
    echo "Sorry!";
    }

    }
     
    ?>
    <html>
    <head>
    <title>Import Questions</title>
    </head>
    <body>
    <form method="post" action="" enctype="multipart/form-data">
    Upload Excel File : <input type="file" name="file" /><br />
    <input type="submit" name="submit" value="Upload" />
    </form>	
    </body>
    </html>

它可以很好地处理英语文本,但在印地语或古吉拉特语文本中会出现问题。如何解决这个问题?

谢谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-12-11 09:17:02

注意,在使用fgetcsv()函数读取数据时,会考虑到locale设置。如果LANGen_US.UTF-8,则该函数读取错误的单字节编码文件。

您可以尝试另一种方法--动态转换.csv文档(用文件编码更改UCS-2 ):

代码语言:javascript
复制
function parse_csv($filename) {
    if (($handle != fopen($filename, "r"))) return false;
    while (($cols = fgetcsv($handle, 1000, "\t")) !== FALSE) {
        foreach( $cols as $key => $value ) {
            $cols[$key] = trim( $cols[$key] );
            $cols[$key] = iconv('UCS-2', 'UTF-8', $cols[$key]."\0") ;
            $cols[$key] = str_replace('""', '"', $cols[$key]);
            $cols[$key] = preg_replace("/^\"(.*)\"$/sim", "$1", $cols[$key]);
        }
        echo var_dump($cols); //This will display an array of your data
    }
}
票数 0
EN

Stack Overflow用户

发布于 2016-12-29 20:53:44

使用上一篇文章的相同想法,只需做一些修改:

代码语言:javascript
复制
function global_client_charset($charset){
if(!isset($charset)){
    $user_agent = strtolower($_SERVER['HTTP_USER_AGENT']);
    if(strrpos($user_agent,"linux")){
    $GLOBALS["CHARSET"] = "UTF-8";
    }else if(strrpos($user_agent,"windows")){
    $GLOBALS["CHARSET"] = "ISO-8859-1";
    }
}else{
        $GLOBALS["CHARSET"] = $charset;
}       
}

function toUTF8($data){
    if($GLOBALS["CHARSET"] === "ISO-8859-1"){
        return iconv("ISO-8859-1", "UTF-8", trim($data));
    }else if($GLOBALS["CHARSET"] === "UTF-8"){
       return trim($data);
    }else{
       return trim($data);
    }
}

if(isset($_POST["submit"]))
{
$file = $_FILES['file']['tmp_name'];
$handle = fopen($file, "r");
$i = 0;

//do you know the charset you are receiving ??
//global_client_charset("ISO-8859-1");
global_client_charset();

while(($filesop = fgetcsv($handle, 1000, ",")) !== false)
{   
    $option1 = $filesop[0];
    $option2 = $filesop[1];
    $option3 = $filesop[2];
    $option4 = $filesop[3];
    $correctans = $filesop[4];
    $question_text = $filesop[5];
    $cat_id = $filesop[6];
    $sub_cat_id = $filesop[7];
    $level_id = $filesop[8];
    $quesimage = $filesop[9];


    $query = "INSERT IGNORE INTO questions (option1, option2,option3,option4,correctans,question_text,cat_id,sub_cat_id,level_id,quesimage) VALUES ('".
    $option1."','".$option2."','".$option3."','".$option4."','".$correctans."','".$question_text."','".
    $cat_id."','".$sub_cat_id."','".$level_id."','".$quesimage."')"; 

    //echo toUTF8($query); die();
    $sql = mysqli_query($con,toUTF8($query));
    $i = $i + 1;        
}

if($sql)
{
    echo "You database has imported successfully. You have inserted ". $i ." records";
}
else
{
    echo "Sorry!";
}
}
?>
<html>
<head>
<title>Import Questions</title>
</head>
<body>
<form method="post" action="" enctype="multipart/form-data">
Upload Excel File : <input type="file" name="file" /><br />
<input type="submit" name="submit" value="Upload" />
</form> 
</body>
</html>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41084385

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档