Ir para conteúdo

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

Tiagotdg

replace

Recommended Posts

Boa tarde, tenho uma duvida e gostaria da ajuda de vocês.

 

tenho uma string que contem $string='

 
<div dir="ltr">
<p><span style="color:#0c4685">. Seguro de Vida por Morte Acidental - %%beneficio%%<br>
. Seguro Invalidez por Acidente - %%beneficio%% <br>
. Auxílio Funeral - R$ %%Valor1%%<br>
. Despesas Médicas e odontológicas - R$ %%Valor2%%<br>
. Assistência Residencial<br>
. Sorteio Mensal: R$ %%Valor3%%<br>
. Desconto em medicamentos de 5% a 70% <br>
. Cesta Básica 6 mensalidades de R$ 120,00 </span><br>
<span style="color:#0c4685">.</span><span style="color:#0c4685"> Assistencia juridica</span></p>
<br>
</div>

 

';

 

Preciso subistituir o que esta entre  %%o que esta aqui%% pelo valor de uma  variavel ex:

%%beneficio%% ='159753'
%%Valor1%% = 1;
%%Valor2%% = 3

 

e assim por diante, eu recebo essa variáveis do banco de dados e devo substitutivas no texto.


se alguém puder ajudar eu agradeço. 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
21 horas atrás, tetsuo disse:

Olá! Use str_replace: http://php.net/manual/pt_BR/function.str-replace.php

ex.:


$string = str_replace('%%beneficio%%', $beneficio_do_database, $string);

 

Vlw pela ajuda mas dessa forma eu teria que passar todas a variáveis, eu gostaria de uma forma mais flexível, talvez por uso de expressão regular, nesse caso, eu teria que percorrer toda string e substituir tudo que estiver por %%VARIAVEL%% 

por um array $substituir = array(

$variavel => 'nome', 

$variavel => 'nome2'

);

 

e assim por diante, a forma que passou usando replace fica muito trabalhoso. 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por mateus.andriollo
      Boa tarde,
      Tenho alguns campos numéricos q ao fazer uma select gostaria q retornasse uma legenda
       
      exemplo:
      Status: 0=Inativo / 1=Ativo Condição: 1=Funcionando / 2=Em manutenção / 3=Manutenção Interna   
      Seria algo assim, tenho varias tabelas com estes campos... mas tenho q ficar usando replace.
      Existe uma forma de criar uma função para isso? Nem q na função eu tenha que setar nome do campo, ficando assim:
      Legenda('Status',cadastro.status) 
    • Por FabianoSouza
      Tenho um campo de descrição no meu sistema... nesse campo preciso fazer um replace de alguns "substrings" que podem existir.
      Exemplos:
      <apelido>apelido</apelido>
      <saudacao>saudacao</saudacao>
       
      Usando CASE e REPLACE para tratar essas substrings aí de cima, funciona para um caso ou para o outro, não ambos.
      Vejam como estou aplicando o SQL.
      ... , CASE WHEN MWA.descMsg LIKE '%'+'<saudacao>saudacao</saudacao>'+'%' Then REPLACE(MWA.descMsg, '<saudacao>saudacao</saudacao>', dbo.saudacao(GETDATE())) WHEN MWA.descMsg LIKE '%'+'<apelido>apelido</apelido>'+'%' Then REPLACE(MWA.descMsg, '<apelido>apelido</apelido>', '[Apelido]') ELSE MWA.descMsg END AS msg ... Preciso fazer com que esse tratamento seja aplicado para todas as situações, não apenas para uma das duas situações.
      O lance é que não tenho como colocar o campo tratado numa variável e ir aplicando o tratamento a ela de forma isolada.
    • Por usuario181474618518
      Bom dia a todos! 
       
      Estou iniciando em PHP, então talvez isso seja uma pergunta burra. Estou utilizando uma plataforma que fornece um array de categorias como digitado abaixo, e minha ideia é fazer uma busca no conteúdo por essas categorias, e substituir elas por outro array, que no caso terá as mesmas categorias, no entanto, com links. Veja:
      $conteudo = "Meu conteúdo Filmes Laranja e Verde. Blackout."; $from = array( 0 => "Laranja", 1 => "Azul", 2 => "Vermelho", 3 => "Verde", 4 => "Black" ); $to = array( 0 => "<a href='#laranja'>Laranja</a>", 1 => "<a href='#azul'>Azul</a>", 2 => "<a href='#vermelho'>Vermelho</a>", 3 => "<a href='#verde'>Verde</a>", 4 => "<a href='#ver'>Black</a>" ); $novoconteudo = strtr($conteudo, array_combine($from, $to)); echo $novoconteudo;  
      O máximo que conseguir fazer foi usando strtr, no entanto acaba fazendo algumas substituições "burras", como por exemplo adicionar link em "Black" quando na verdade a palavra é "Blackout". Acredito que para resolver isso, deveria ser feito com preg_replace, porém já tentei e não consegui. Alguém pode me ajudar?
       
      Veja: http://sandbox.onlinephpfunctions.com/code/e7cfd27ea182041de0519df3ed22bedc93cda18b
    • Por FabianoSouza
      Olá pessoal. Tenho uma base com uns 5.000 registros.
      Quero fazer um código para aplicar acento em nomes que foram gravados sem sua respectiva acentuação.
       
      Parte 1
      Até consegui montar uma código para testes usando UPDATE e replace.
      Mas da forma como criei, se peço para acentuar a string Jose, acaba acentuando também Josevaldo (pois ambos tem a string "jose")
      Preciso de um código que pegue cada parte do nome  (primeiro nome, nome do meio e último nome) da pessoa e verifique se há o valor passível de aplicar a acentuação.
       
      Exemplo:
      Jose Amancio dos Santos - teria que aplicar acento no Jose e em Amancio.
      Josevaldo Pires Silva - não deve aplicar acento em Josevaldo
       
       
      Parte 2
      Como isso será uma rotina, quero ter um "dicionário" de nomes gravados da forma correta (acentuados) para serem usados na rotina de que aplicaria a acentuação.
      Queria ver sugestões de como montar esse "dicionário". Seria um array? Seria ler uma tabela?
       
       
      Podem ajudar?

      Valew!
       
    • Por FabianoSouza
      Pessoal, to apanhando para criar uma function para remover a última vírgula que aparece na string chamada beneficios.
      Estava tentando isso:
      ... REVERSE(STUFF(REVERSE( ---------------------------------- CASE WHEN valeTransporte = '1' Then 'Vale-transporte,' ELSE '' END + CASE WHEN valeRefeicao = '1' Then 'Vale-refeição,' ELSE '' END + CASE WHEN seguroDeVida = '1' Then 'Seguro de vida,' ELSE '' END ---------------------------------- ), 1, 1, '')) AS 'beneficios' ... O problema é que nem sempre haverá string para ser tratada, aí o campo aparece como NULL e gera problema na hora de gerar um JSON pela aplicação.
      Preciso de uma function que previna a situação de não haver string, e retorne valor vazio (não NULL).
       
      Valew!
       
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.