Jump to content
Sapinn

Destacar o que foi alterado em um texto

Recommended Posts

Salve quebrada, firmesa? É o seguinte estou desenvolvendo um web site em que os aluno enviam textos para o professor corrigir. O que eu quero é que quando o professor corrigir o texto e aluno for ver mostrar o que foi corrigido. 

Por exemplo se o aluno digitar a seguinte frase:

Eu gosta mas de você.

Quando ele for ver a correção terá:

Eu gosto mas(o correto seria "mais") de você.

 

Alguém pode me ajudar aqui?

 

Share this post


Link to post
Share on other sites

Cara, acredito que têm muitas classes prontas que fazem isso, você não precisará reinventar a roda.

 

Veja: https://github.com/gorhill/PHP-FineDiff / http://www.raymondhill.net/finediff/viewdiff-ex.php

 

Vários exemplos: https://pt.stackoverflow.com/questions/292565/comparar-textos-php

 

Tente algo, se tiver dificuldade posta aí.

Share this post


Link to post
Share on other sites

Oi acho que nesse caso você precisaria trabalhar com algum tipo de IA para adicionar essas variáveis de mais e etc a string de comparação... parece ser um sistema bem complexo gostaria de acompanhar o andamento da sua solução.

 

Se puder, compartilhe conosco.

 

Se você quiser comparar um texto com o outro, você pode utilizar o código abaixo:

<?php 
    function get_decorated_diff( $old, $new )
    {
        if( $old != $new )
        {
            $old = strip_tags($old);
            $new = strip_tags($new);

            $from_start = strspn( $old ^ $new, "\0" );        
            $from_end   = strspn( strrev($old) ^ strrev($new), "\0" );

            $old_end = strlen($old) - $from_end;
            $new_end = strlen($new) - $from_end;

            $start  = substr( $new, 0, $from_start );
            $end    = substr( $new, $new_end );
            $new_diff = substr( $new, $from_start, $new_end - $from_start );  
            $old_diff = substr( $old, $from_start, $old_end - $from_start );

            $new = "$start<ins style='background-color:#ccffcc'>$new_diff</ins>$end";
            $old = "$start<del style='background-color:#ffcccc'>$old_diff</del>$end";
        }
        
        return array("old"=>$old, "new"=>$new);
    }


    $str1 = 'Oi André, tudo bem com você ?';
    $str2 = 'Oi André, tudo certo com você ? ';

	
	$comparacao = get_decorated_diff($str1, $str2);
   var_dump($comparacao);

 

 

Abraço.

Share this post


Link to post
Share on other sites

Andre Severino, gostaria de agradecer pela sua resposta graças a ela pude resolver melhor o meu problema. Entretanto, eu tenho uma duvida nesse mesmo contexto em relação. É o seguinte gostaria que a pessoa que fosse corrigir o texto para destacar de vermelho colocasse as {{ }} entre as palavras. Por exemplo:

O que é digitado pelo aluno:

 Eu gosto mas de você

Na correção o  professor colocaria 

Eu gosto {{mas}} de você {{(o certo seria mais por representar adição)}}.

e quando o aluno visse a correção veria assim:

Eu gosto mas de você ( o certo seria mais por representar adição).

 

As {{ }} que eu sitei foram só um exemplo poderia ser qualquer outro simbolo.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By eduardaarosaa
      Eu estou fazendo um sistema com multipolos uploads de aquivos.
       
      Aqui ele está movendo o arquivo para pasta upload: 
       $upload = $request->image[$i]->storeAs('upload', $nameFile);
      Ao dar var_dump nesta variável ela retorna: 
       
       string(38) "upload/172118201908225d5ef93e4d803.png" string(38) "upload/172118201908225d5ef93e4f9b2.png" string(38) "upload/172118201908225d5ef93e50899.png" string(38) "upload/172118201908225d5ef93e51b72.png"
       
      São os 4 arquivos que deram upload, porém está em string e eu queria usar em array para separar em variáveis e adicionar no banco. 
       
      Use o explode assim: 
      $array = explode(",", $upload);
      Então ele retornou vários arrays com o mesmo indice: 
       
      array(1) { [0]=> string(38) "upload/172322201908225d5ef9ba3cf15.png" } array(1) { [0]=> string(38) "upload/172322201908225d5ef9ba3edab.png" } array(1) { [0]=> string(38) "upload/172322201908225d5ef9ba3fbcc.png" } array(1) { [0]=> string(38) "upload/172322201908225d5ef9ba4163a.png" }
       
      Como faço para poder separar esses arrays? Ou mudar os índices? Se alguém souber .. 
      Obrigada!!!
       
    • By gabrielslessa
      Olá amigos, estou com uma dúvida, não estou conseguindo gravar os dados contidos numa sessão no bd mysql com conexão PDO. Tenho uma sessão onde estão todos os produtos do carrinho de compras em php, como faço para gravar esses itens separadamente no bd? Obrigado desde já!
       
      código onde está gravando no bd (primeiro grava os dados do post e depois grava os dados da sessao:
       
      //gravando no bd $this->db->insert('as_pedidos', array( "user_id" => $userId, "ped_rua" => $ped_rua, "ped_numero" => $ped_numero, "ped_cep" => $ped_cep, "ped_bairro" => $ped_bairro, "ped_vtotal" => $ped_vtotal, "ped_frete" => $ped_frete, "ped_distance" => $ped_distance, "ped_forma_pg" => $forma_pagProtect, "ped_comentario" => obsProtect, "ped_vtroco" => $trocoProtect, "ped_acresc_cred" => $acresc_credProtect, "ped_op_cred" => $opProtect, "ped_hora" => date('Y-m-d H:i:s') )); $ped_id = $this->db->lastInsertId(); foreach($_SESSION["products"] as $dado => $value) : NÃO ESTOU CONSEGUINDO A PARTIR DAQUI.... //gravando no bd $this->db->insert('as_ped_itens', array( "id_prod" => $product['id'], "qtd" => $product['product_qty'], "nome_prod" => $product['nome'], "valor" => $product['preco'], "id_ped" => $ped_id )); endforeach;  
       
       
      Código onde grava os dados na sessão ($_SESSION["products"]):
       
      setlocale(LC_MONETARY,"pt_BR"); # add products in cart if(isset($_POST["id"])) { foreach($_POST as $key => $value) : $product[$key] = filter_var($value, FILTER_SANITIZE_STRING); endforeach; $id = preg_replace( '/[^0-9]/is', '', $product['id'] ); $product_qty = preg_replace( '/[^0-9]/is', '', $_POST["product_qty"] ); $statement = app('db')->prepare("SELECT as_produtos.nome, as_produtos.preco, as_produtos.acresc FROM as_produtos WHERE id = :id LIMIT 1"); $statement->bindParam(':id', $id, PDO::PARAM_INT); $statement->execute(); foreach($statement as $dados_produto) : $product["product_name"] = $dados_produto["nome"]; $product["product_price"] = $dados_produto["preco"]; $product["product_acresc"] = $dados_produto["acresc"]; if(isset($product["product_name"])){ if(isset($_SESSION["products"][$id])) { $_SESSION["products"][$id]["product_qty"] = $_SESSION["products"][$id]["product_qty"] + $_POST["product_qty"]; } else { $_SESSION["products"][$id] = $product; } } else { $_SESSION["products"][$id] = $product; } endforeach; //exibindo o total de itens $total_product = array_sum(array_column($_SESSION['products'], 'product_qty')); //exibindo o total de produtos //$total_product = count($_SESSION["products"]); die(json_encode(array('products'=>$total_product))); }  
       
    • By Salvatore
      Galera alguem poderia me explicar como faço isto ultilizando php? estou perdido
      tenho que usar varias imagens?
       
      De acordo que ele clica e seleciona a poltrona ela muda de cor 
      RED: OCUPADA
      AZUL: LIVRE

    • By drx
      Olá feras!
       
      Estou recebendo este retorno da conexão: SQLSTATE[HY000] [1049] Base 'dbbase' inconnue
       
      O que é que pode ser?
       
      Tudo certinho. Fala que a dbbase não existe, mas existe.
      Alguém tem uma solução ?
       
      Desde já agradeço.
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.